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SECTION 1 
INTRODUCTION 



The MC68451 memory management unit (MMU) provides address translation and protection for the 
16 megabyte addressing range of the MC68000 MPU. Each bus master (or processor) in the M68000 
Family provides a function code and an address during each bus cycle. The function code specifies 
an address space and the address specifies a location within that address space. The function codes 
distinguish between user and supervisor spaces and, within these, between data and program 
spaces. This separation of address spaces provides the basis for memory management and protec- 
tion by the operating system. Provision is also made for other bus masters, such as the MC68450 
DMAC, to have separate address spaces for logical DMA. A multitasking operating system is 
simplified and reliability is enhanced through the use of the MMU. 

Features of the MC68451 include: 

• MC68451F — Faster Translation Times 

• Compatible with MC68000 and MC68008 

• Provides Virtual Memory Support for the MC68010 

• Provides Efficient Memory Allocation 

• Separates Address Spaces of System and User Resources 

• Provides Write Protection 

• Supports Paging and Segmentation 

• 32 Segments of Variable Size with Each MMU 

• Multiple MMU Capability to Expand to Any Number of Segments 

• Allows Inter-Task Communication through Shared Segments 

• Quick Context Switching to Cut Operating System Overhead 

• Simplifies Programming Model of Address Space 

• Increases System Reliability 

• DMA Compatible 

The MC68451 memory management unit (MMU) is the basic element of a memory management 

mechanism (MMM) in an M68000 Family system. The operating system is responsible for insuring 
the proper execution of user tasks in the system environment and memory management is basic to 
this responsibility. The MMM provides the operating system with the capability to allocate, control, 
and protect the system memory. A block diagram of a single-MMU system is shown in Figure 1-1. 

An MMM, implemented with one or more MC68451 MMUs, can provide address translation, 
separation, and write protection for the system memory. The MMM can be programmed to cause 
an interrupt when a chosen section of memory is accessed and can directly translate a logical 
address into a physical address making it available to the MPU for use by the operating system. 
Using these features, the MMM can provide separation and security for user programs and allow 
the operating system to manage the memory in an efficient fashion for multitasking. 
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Figure 1-1. Simplified Blocl( Diagram of Single-MIVIU System 



1.1 IVIEMORY SEGIVIENTS 

The MMM partitions the logical address space into contiguous pieces called segments. Each seg- 
ment is a section of the logical address space of a task which is mapped via the MMM into the 
physical address space. Each task may have any number of segments. Segments may be defined as 
user or supervisor, data-only or program-only, or program and data. They may be accessed by only 
one task or shared between two or more tasks. In addition, any segment can be write protected to 
insure system integrity. A fault (MC68000 bus error) is generated by the MMM if an undefined seg- 
ment is accessed. 



1.2 FUNCTION CODES AND ADDRESS SPACES 

Each bus master in the M68000 Family (including the MC68440 DMA controllers) provides a func- 
tion code during each bus cycle to indicate the address space to be used for that cycle. The address 
bus then specifies a location within this address space for the operation taking place during that bus 
cycle. 

The function codes appear on the FC0-FC2 lines of the MC68000 and divide the memory references 
into two logical address spaces — the supervisor and the user spaces. Each of these is further 
divided into program and data spaces. A separate address space is also provided for internal CPU- 
related activities such as interrupt acknowledge, giving a total of five defined function codes. The 
address space of the MC68000 is shown in Figure 1-2. 

In addition to the 3-bit function code provided by the MC68000, the MC68451 MMU also allows a 
fourth bit (FC3) which provides for the possibility of a nother b us master in the system. In this case, 
FC3 would be a function of bus grant acknowledge (BGACK) of the MC68000 to enable a second 
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Figure 1-2. Address Space of MC68000 

set of eight function codes. This raises the total number of possible function codes to sixteen. If 
there is only one bus master (the MPU), the FC3 pin on the MMU should be tied low and only eight 
address spaces can then be used. 



1.3 ADDRESS SPACE NUMBER 



Each task in a system has an address space which is comprised of all the segments defined for that 
task. This address space is assigned a number by programming all the address space number (ASN) 
fields in its descriptors with the same value. This value can be considered a task number. The cur- 
rently active task's number is kept in the appropriate entry(s) in the address space table (AST). 

The AST is a set of MMU registers which defines which task's segments are to be used in address 
translation for each cycle type (supervisor program, supervisor data, etc). The AST contains an 
8-bit entry for each possible function code. Each entry is assigned an ASN (task number) and this is 
used to select which descriptors may be used for translation. The logical address is then translated 
by one of these to produce the physical address. Figure 1-3 is a typical memory map of a task's ad- 
dress space. 



lACK 



Supervisor 
Program Data 



User 



Program 



Data 



lACK 



▼ 

FFFFF 




t 

FFFFF 



'////////, Task #01 Segment 

Figure 1-3. Memory Map of Typical Task Address Space 
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1.4 DESCRIPTORS 



Address translation is done using descriptors. A descriptor is a set of six registers (nine bytes) which 
describe a memory segment and how that segment is to be mapped to the physical addresses. Each 
descriptor contains base addresses for the logical and physical spaces of each segment. These base 
addresses are then masked with the logical address masks. The size of the segment Is then defined 
by "don't cares" in the masks. This method allows segment sizes from a minimum of 256 bytes to a 
maximum of 16 megabytes In binary increments (i.e., powers of two). This also forces both logical 
and physical addresses of segment boundaries to lie on a segment size boundary. That is, a seg- 
ment can only start on an address which is a multiple of 2k. The segments can be defined in such a 
way to allow them to be logically or physically shared between tasks. Descriptor mapping is shown 
schematically in Figure 1-4. 
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Figure 1-4. Schematic Diagram of Descriptor IVIapping 



1.5 TRANSLATION 

During normal translation, the MMU translates the logical address provided by the MC68(XX) to pro- 
duce a physical address which is then presented to the memory array. This is accomplished by 
matching the logical address with the information in the descriptors and then mapping It Into the 
physical address space. A block diagram of the MC68451 MMU is shown in Figure 1-5. 

Refer to Figure 1-1 for the following. The logical address is composed of address lines A1-A23. The 
upper 16 bits of this address (A8-A23) are translated by the MMU and mapped into a physical ad- 
dress (PA8-PA23). The lower seven bits of the logical address (A1-A7) bypass the MMU and 

become the low-order physical address bits (PA1-PA7). In addition, the data strobes (UDS and 
LPS) remain unmapped to become the physical data strobes for a total of eight unmapped address 
lines. 
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SECTION 2 
SIGNAL DESCRIPTION 



This section contains a brief description of the input and output signals. 

NOTE 

Throughout this document, active low signals are denoted by a superscript bar. This does 
not innply logical negation. To avoid confusion, a signal in its true state is said to be 
asserted whether that signal is active high or low. It is said to be negated when it is in its 
functionally inactive state. A signal which can be placed in the high-impedance state is 
said to be three-stated. A signal line which is first negated and then placed in the high- 
impedance state is said to be rescinded. 

Some MMU signal lines are classed as input/output meanir^^I that the bus buffers can be directed 
inward to input information into the MMU or outward to drive the bus. These signals must be either 
inputs or outputs at any given time, they may not be both. An example is the PAD port. 

Still other types of signals can logically be both inputs or outputs at the same time. The internal 
signal controller may assert or negate a signal and read it at the same time. To distinguish between 
them, the suffix "in" will be used to denote the input signal and the suffix "out" will be used for the 
output signal. 

Six pins on the MMU have this property - IRQ, FAULT, MAS, GO, ANY, and ALL. In a multiple- 
MMU system, they would be wired i n par allel to provide a single-signal level for the entire system. 
Of these, three pins - IRQ, FAULT, and ANY - are active low, wire-OR type signals. As such, 
asserting any one of the parallel pins will drive the line low (true). If any of these signals are asserted 
on any MMU in the system, they will be detected as asserted on the corresponding "in" pin of all 
MM Us in the system. 

The ALL pin is an active-high open-drain gate and, as such, all pins are wire-ANDed and must be 
pulled high in order for the input to be high. Therefore, even if ALLout is asserted by an MMU, 
ALLin will not be detected true by any MMU unless all of the corresponding pins on all MMUs in the 

system are asserted. 

The GO and MAS pins are not open drain but they can be put in the high-impedance state. They 
should each be wired in parallel on all MMUs in the system since only one MMU at any given time 
will assert these signals. A pullup resistor is required to hold the signal inactive when the pin is in the 
high-impedance state. 

2.1 VCC AND GND 

These pins supply power to the MMU. The two Vqc pins are + 5 volts ± 5% and the two GND pins 
are ground. 
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2.2 CLOCK 

This TTL input signal must be the MC68000 system clock and must not be gated off at any time. 

2.3 CHIP SELECT (CS) 

CS is an input used to activate the MMU for accesses to the registers and other MMU operations. 
The assertion of CS, in conjunction with the address of a global operation on pins RS1-RS5, selects 
the MMU to be a master for that operation. CS should be decoded from the physical address bus to 
protect the MMU registers from unauthorized access. See 4.6 MMU OPERATIOISIS. 



2.4 REGISTER SELECTS (RS1-RS5) 

These five input pins should be the lower five bits of the physical address bus. When CS is asserted, 
these pins select the operation to be performed and the register involved (if any). See Table 4-3 for 
the operations address map. 

2.5 READ/WRITE (R/W) 

The R/W input signal controls the direction of the data bus during an MMU operation. It is also 
used to compare against the matched descriptor to determine if a write violation has occurred dur- 
ing translation. 



2.6 RESET 

Asserting the RESET input will reset the MMU regardless of what state it is in. T he RES ET pin must 
be held low for at least 16 clock cycles to reset the MMU. During power up, the RESET pin must be 
held low for at least 100 milliseconds after Vcc is established and the clock signal is present. See 
4.5.1 The Reset State. 

2.7 DATA TRANSFER ACKNOWLEDGE (DTACK) 

The MMU uses this rescindable output to signal the completion of the operat ion pha se of a bus 
cycle to the processor. If the bus cycle is a processor read, the MMU asserts DTACK to indicate 
that the information on the data bus is valid. If the bus cycle is a processo r write to the MMU, 
DTACK is used to acknowle dge ac ceptance of the data by the MMU. DTACK may be asserted only 
by an MMU that has CS or lACK asserted. 

2.8 UPPER AND LOWER DATA STROBES (DDS, LDS) 

The UDS and LDS inputs are used during MMU operation (processor access of MMU registers) to 
indicate which byte of the data bus is to be used. The assertion of the upper data strobe indicates 
that the operation is to be performed at an even address using the upper byte of the data bus. The 
assertion of lower data strobe indicates that the operation is to be performed at an odd address us- 
ing the lower byte of the data bus. During a processor write operation, the data strobes indicate to 
the MMU that valid data is on the data bus. 
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2.9 ADDRESS STROBE (AS) 



This input signal indicates to the MMU that a bus cycle is in progress, and that there is a valid 
address on the logical address bus. The assertion of AS initiates the normal translation phase of the 
bus cycle. 

2.10 PHYSICAL ADDRESS AND DATA (PAD0-PAD15) 

During MMU operations, these 16 nnultiplexed input/output pins function as the data bus used to 
transfer data to and fronn the MMU. During nornnal translation, the physical address PA8-PA23 is 
gated out on this bus. External octal data transceivers are used to isolate the system data bus from 
the physical address bus. The MMU provides the enable data (ED) signal to control these 
transceivers. See 2.11 ENABLE DATA for more detail. 

2.11 ENABLE DATA (ED) 

The enable data signal is a three-state output signal used to control the external bus transceivers on 
the PAD0-PAD15 bus. When ED is asserted, the transceivers should be enabled (i.e., they should 
drive the bus). When ED is negated, the transceivers should be in the high-impe dance state. R/W is 
used to control the direction of the transceivers. Only the MMU with CS or lACK asserted will 
assert ED. 

NOTE 

A pair of SN74LS245 type data transceivers may be used. ED will drive the output enable 
pin with no additional logic. See the circuit diagram in Section 4 (Figure 4-1). 

2.12 HOLD ADDRESS (HAD) 

HAD is a rescindab le ou tput used to control an external latch on the physical address bus. After 
normal translation, HAD is asserted to h old th e physical address stable. The latch should be of the 
transparent type such as an SN74LS373. HAD can directly interf ace w ith the enable pin of this type 
of latch. To provide address hold time, HAD is rescinded after MAS is rescinded. 

2.13 MODE 

MODE is a three-level input used to program the mode of operation of the MAS signal. There are 
three modes of operation: A, SI, and S2. 

Mode A is selected by leaving the MODE pin unconnected. Mode SI is selected by tying the MODE 
pin to Vcc and mode S2 is selected by tying the MODE pin to ground. For description of the dif- 
ferent modes, see SECTION 5 HARDWARE CONSIDERATIONS. 

2.14 INTERRUPT REQUEST (IRQ) 

IRQ is an open-drain input/ output signal. IRQout is used to request an interrupt of the MPU. 
IRQout is asserted if a descriptor in which the I (interrupt) bit is set, is matched in normal transla- 
tion, and the interrupt enable (IE) bit in the global status register (GSR) is set. Clearing all IP (inter- 
rupt pending) bits in all segment status registers or clearing IE in the GSR will cause IRQ to be 
negated. If fRQin and lACK, and UDS and/or LDS, are asserted, the MMU will perform an interrupt 
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acknowledge operation. See 4.6 MMU OPERATIONS. The IRQ lines of all MMUs should be wire- 
ORed together and tied to Vcc through a pullup resistor. They should be isolated from the IRQ lines 
of other devices to prevent an MMU from detecting an erroneous interrupt. 



2.15 INTERRUPT ACKNOWLEDGE (lACK) 

An MMU will begin the interrupt acknowledge operation if iRQin and lACK are both asserted. The 
interrupt vector supplied by the interr upt ve ctor register (I VR) is placed on the data bus for the 
MRU. Only one MMU should have its lACK pin tied to the lACK circuitry from the processor; all 
other MMUs should have this pin tied high (inactive). 



2.16 FAULT 

FAULT is an open-drain input/output signal. During no rmal tra nslation, if an MMU detects a write 
violation or an undefined segment access, it asserts the FA ULT line for five clock cycles or until AS 
becomes negated, whichever is longer. If a n MMU detects FAULTin asserted, it updates its global 
and local status registers to reflect this. The FAULT lin es of all MMUs in the system should be wire- 
ORed and tie d to V cc through a pullup refeistor. The FAULT signals can be connected directly to 
the MC68000 BERR pin but they should be isolate d from a ny other bus error signals in the system to 
prevent the MMUs from detecting an erroneous FAULT. 

2.17 FUNCTION CODES (FC0-FC3) 

The function code inputs specify the type of bus cycle being executed by the current bus master. 
The function code indicates which address space is to be used for that cycle and is used to index 
into the address space table for the cycle address space number used in descriptor matching. See 
1.2 FUNCTION CODES AND ADDRESS SPACES. 

2.18 ADDRESS BUS (A8-A23) 

These inputs are the upper 16 bits of the MPU address bus. They form the logical address which the 
MMU translates into 16 physical-address bits. The lower seven address lines (A1-A7) bypass the 
MMU. 

2.19 GLOBAL OPERATION (GO) 

GO is a rescindable input/output inter-MMU signal used in multiple-MMU systems to indicate or 
detect global operations. If CS is asserted and the operation to be performed is global, the MMU is 
selected as the master MMU for that operation. GOout is then asser_ted by the master MMU to 
signal other MMUs that they are slaves in a global operation. Thus, if GOin is asserted while CS is 
negated, the MMU is selected as a slave for that operation. For a detailed description, see 4.6 MMU 
OPERATIONS. 



2.20 ANY 

The ANY signal is an open-dr ain in put/output inter-MMU handshake signal for multiple-MMU 
systems. A slave MMU asserts ANYout during a global operation if it h as a lo cal event to report 
which is significant if it occurs in one, but not necessarily all, MMUs. The ANY pins are wire-ORed 
and require a pullup resistor to VcC- 
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2.21 ALL 



The ALL pin is an open-drain input/output similar to ANY except that it reports events that are 
significant only when they occur in all MMUs. The ALL pins are wire-ANDed together and require a 
pullup resistor to VcC- 



2.22 MAPPED ADDRESS STROBE (MAS) 

MAS is a resclndable input/output signal. MASout is asserted by an MMU if an address match 
occurs during no rmal t ranslation. This indicates that a valid physical address is present at the PADO- 
PAD15 outputs. MASin is used by an MMU to detect a successful translation by another MMU. 
MAS can be programmed to operate in an asynchronous or synchronous mode by the MODE pin. 



2.23 WRITE INHIBIT (WIN) 

WIN is a rescindable output provided to protect write- protected segments during re ad-mod ify-write 
bus cycles. No rmally , write- protected segments are protected by the assertion of FAULT and the 
withholding of MAS upon detection of an attempted write to that segment. However, during read- 
modify-write bus cycles, AS remains asserted, making it difficult to prevent the write portion of the 
instru ction from writing to the protected segment. To proviou write protection during these instruc- 
tions, WIN should be in cluded in the decoding of the physical data strobes. See 5.2 PHYSICAL 
DATA STROBES. WIN is asserted with MAS each time a write-protected segment is accessed, 
whether the access is a read or a write. 

NOTE 

In multiple-MMU systems, MAS, HAD, WIN, FAULT, DTACK, ED, and GO should be 
connected in parallel to their respective pins on all MMUs. Each should be tied to Vcc 
through a pullup resistor to insure that the signal is negated while the pin is in the high- 
impedance state. 
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SECTION 3 
REGISTER DESCRIPTION 



Figure 3-1 shows a programmer's model of the MMU. The MMU registers consist of two groups: 
the descriptors and the system registers. Each of the 32 descriptors is nine bytes long and defines 
one memory segment. See 3.1 DESCRIPTORS. 



Logical Base Address 



Logical Address Mask 



Physical Base Address 



Address Space 

Number 
Address Space 
Masic 

I 8 Bits i 



Segment Status 



(a) Descriptors (32) 



-8 Bits- 



Segment Status Register 



u 






1 


IP 


M 


WP 


E 



Address Space 
Table 



8 BitS' 



ASTO 



AST1 



AST2 



AST3 



AST4 



AST5 



AST6 



AST? 



AST8 



AST9 



AST10 



ASTll 



AST12 



AST13 



AST14 



AST15 



Address 

$0 
$2 
$4 



$A 

$C 

SE 

$10 

S12 

$14 

$16 

$18 

$1A 

$10 

$1E 



(b) System Registers 



AGO 
AC2 
AC4 
AC6 
ACS 



Accumulator 
8 Bits >\< 8 Bits ■ 



Logical Base Address/ Translation Register 



Logical Address Mask 



Physical Base Address/Translation Register 



Address Space 

Number 
Address Space 
Mask 



Segment Status 
Register 



Miscellaneous Registers 



ACI 
ACS 
AC5 
AC7 





7 


6 


5 


4 


3 


2 


1 


0 


Address 


Descriptor Pointer 








DP4 


DPS 


DP2 


DPI 


DPO 


$29 


Interrupt Vector 
Register 


IV7 


!V6 


IV5 


IV4 


IV3 


IV2 


IVl 


IVO 


$2B 


Global Status 
Register 


F 


DF 












IE 


$2D 


Local Status 
Register 


L7 


L6 


L5 


L4 


RW 


GAT 


GAL 


LIP 


$2F 


Interrupt Descriptor 
Pointer 


NVI 






14 


13 


12 


11 


10 


$39 


Result Descriptor 
Pointer 


NVR 






R4 


R3 


R2 


R1 


RO 


$3B 



Figure 3-1. Programmer's Model 
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In the following discussion, a segnnent access is defined as a successful match occurring on a seg- 
ment during normal translation. 

The system registers contain both information local to the MMU and information global to the 
MMM. Each bit in the system registers and the segment status registers, except the address space 
table, is one of four types: 

Control Control bits can be set or cleared by the MPU to select MMU op- 

tions. These are read/write bits. 

Status Alterable SA bits are set or cleared by the MMU to indicate status information. 
These are also read/write bits. 

Status Unalterable SU bits are set or cleared by the MMU to reflect status information. 
These bits cannot be written by the MPU. 

Reserved Reserved bits are reserved for future expansion. They cannot be writ- 

ten and are zero when read. 

The system registers are all directly addressable from the physical-address space. Accessing 
registers causes certain operations to be performed. See 4.6.1 Operations Address Map for the 
locations of system registers. The descriptors are not directly addressable, but are accessed using 
the descriptor pointer and the accumulator. 

3.1 DESCRIPTORS 

Each MMU contains 32 descriptors (0-31), each of which can define one memory segment. A 
descriptor is loaded by the MPU using the accumulator and descriptor pointer with a load descriptor 
operation. The segment status register (SSR) can be written to by the MPU indirectly using the 
descriptor pointer. Each descriptor consists of the following registers. 

3.1.1 Logical Base Address (LBA) 

The LBA is a 16-bit register which, together with the logical address mask (LAM), defines the 
logical addressing range of a segment. This is typically the first address in the segment, although it 
can be any address within the range defined by the LAM. 

3.1.2 Logical Address Mask (LAM) 

The LAM is a 16-bit mask which defines the bit positions in the LBA which are to be used for range 
matching. Ones, in the mask, mark significant bit positions while zeroes indicate "don't care" posi- 
tions. A range match occurs if, in each bit position in the LAM which is set to one, the LBA 
matches the incoming logical address. The matching function is depicted schematically in 
Figure 3-2. 




Match! n) 



Figure 3-2. Schematic Logic of Address Matching 
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3.1.3 Physical Base Address (PBA) 



The PBA is a 16-bit address which, with the LAIVI and the incoming logical address, is used to form 
the physical address. The logical address Is passed through to the physical address in those bit posi- 
tions in the LAM which contain zeroes (the "don't cares") and the PBA is gated out in those posi- 
tions which contain ones. A schematic representation of the physical address generation 
mechanism is shown in Figure 3-3. 




Figure 3-3. Schematic Logic of Physical Address Generation 
3.1.4 Address Space Number (ASN) 

The ASN is an 8-bit number which, together with the address space mask, is used in detecting a 
match with the cycle address space number. 



3.1.5 Address Space Mask (ASM) 

The ASM is an 8-bit mask which defines the significant bit positions in the ASN which are to be 
used in descriptor matching. As in the LAM, the bit positions which are set are used for matching 
and the bit positions that are clear are "don't cares". A space match occurs if, in the significant bit 
positions, the cycle address space number matches the ASN. Address space matching is sche- 
matically similar to logical address matching as shown in Figure 3-2. 



3.1.6 Segment Status Register (SSR) 

Each descriptor has an 8-bit SSR. The SSR can be written to in two ways: using the load descriptor 
operation or indirectly using the descriptor pointer in a write status register operation. Each bit is 
labeled as control or status alterable. Bits 5 and 6 are reserved for future use. 

7 6 5 4 3 2 1 0 .... ,u 

Addressed indirectly through 



WP I E 



the descriptor pointer 



U (used) is set by the MMU if the segment was accessed since it was defined. This bit 
is status alterable. 

Set: a) By a segment access (successful translation using the segment) 

b) By an MPU write of "1" 
Cleared: a) Reset (in segment #0 of master) 

b) MPU write of "0" 



If the I (interrupt) control bit is set, an interrupt is generated upon accessing the seg- 
ment. 

Set: a) MPU writes a "1" 
Cleared: a) MPU writes a "0" 

b) Reset (segment #0 of master) 
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IP IP (interrupt pending) is set if the I bit Is set when the segment is accessed. IRUout is 
asserted if an IP bit, in one or more SSRs, is set and IE in the global status register 
(GSR) is set. IRQout is negated when all the IP bits in all SSRs are clear or IE Is cleared. 
IP is status alterable and should be cleared by the interrupt service routine. 
Set: a) Segment access and I is set 

b) MPU writes a "1" 
Cleared: a) MPU writes a "0" 

b) Reset (in segment #0 of master) 

c) E bit is a "0" 

M The M (modified) bit is set by the MMU if the segment has been written to since it was 
defined. The M bit Is status alterable. 
Set: a) Successful write to the segment 

b) MPU writes a "1" 
Cleared: a) MPU writes a "0" 

b) Reset (segment #0 in master) 

WP If the WP (write protect) control bit is set, the segment is write protected. A write ac- 
cess to the segment with WP set will cause a write violation. 
Set: a) MPU writes a "1" 
Cleared: a) MPU writes a "0" 

b) Reset (segment #0 in master) 

E E (enable) is a control bit which, when set, enables the segment to participate in the 
matching process. E can be cleared (the segment disabled) by a write to the SSR, but a 
load descriptor operation must be performed to set it. 
Set: a) Load descriptor operation with AC7, bit #0 set 

b) Reset (segment #0 in master) 
Cleared: a) MPU writes a "0" 

b) Unsuccessful load descriptor operation on this descriptor 

c) Load descriptor operation with AC7, bit #0 cleared 



3.2 SYSTEM REGISTERS 

The system registers consist of the address space table, accumulator, and miscellaneous registers 
which include global status register, local status register, descriptor pointer, result descriptor 
pointer, interrupt descriptor pointer, and interrupt vector register. Each of these registers is 
described below. 



3.2.1 Address Space Table (AST) 

Each MMU has a local copy of the AST. This table is organized as 16 8-bit, read/ write registers 
located at even byte addresses starting at address $00. Each entry is programmed by the operating 
system with a unique address space number, each of which is associated with a task. During a 
memory access, the MMU receives a 4-bit function code (FC0-FC3) which is used to index into the 
AST to select the cycle address space number. This number is then used to check for a match with 
the ASN in each of the 32 descriptors within the MMU. 
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The MC68000 MPU and the MC68450 DMA C only p rovide a 3-bit function code, FC0-FC2. In a 
system with more than one bus master, the BGACK signal from the MPU could be inverted and 
used as FC3. This would result in the AST organization shown in Figure 3-4. 
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Figure 3-4. Address Space Table Organization 



3.2.2 Accumulator (AC0-AC8) 

The accumulator (shown in Figure 3-1) is used to access the descriptors, perform direct translation, 
and latch information during a fault. The accumulator consists of nine 8-bit registers located at byte 
addresses from $20 to $28. The register assignments for each operation in which it participates is 
shown in Table 3-1. 



Table 3-1 . Accumulator Assignments for Operations 



Register 
Assignment 


Load/ Read Descriptor 


Direct Translation 


Normal Translation (Fault) 


Address 


AGO 


Logical Base Address (MSB) 


Logical Translation Register (MSB) 


Logical Address (MSB) 


$20 


ACl 


Logical Base Address (LSB) 


Logical Translation Register (LSB) 


Logical Address (LSB) 


S21 
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Logical Address Mask (MSB) 






$22 


ACS 
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Address Space Number (ASN) 
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AC7 


Segment Status Register (SSR) 
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Address Space Mask (ASM) 






$28 
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3.2.3 Global Status Register (GSR) 



The GSR is an 8-bit register used to reflect faults and to enable interrupts from an MMU. All MMUs 
maintain identical information in their GSRs. Bits 1, 2, 3, 4, and 5 are reserved for future use. The 
organization of the GSR is shown below. The GSR is located at address $2D. 

7 6 5 4 3 2 1 0 



GSR F DF 



T 1 1 1 1 1 Address 



F F (fault) Is a status alterable bit that is set by the MMU whenever FAULTin is detected. 
Clearing the F bit automatically clears bits L4-L7 in the local status register. 
Set: a) Write v iolation detected in this MMU 

b) FAULTin detected 

c) ALLin detected (undefined segment access) 

d) MPU writes a "1" 
Cleared: a) Reset asserted 

b) MPU writes a "0" 

DF DF (double fault) is set if a FAULTin signal was detected with F set. DF is a status 
alterable bit. 

Set: a) Fault occurs and F was previously set 

b) MPU writes a "1" 
Cleared: a) Reset 

b) MPU writes a "0" 

IE If IE (interrupt enable) is set, the interrupt-request line is enabled. This is a read/write 
control bit. 

Set: a) MPU writes a "1" 
Cleared: a) Reset 

b) MPU writes a "0" 



3.2.4 Local Status Register (LSR) 

The LSR is an 8-bit register which reflects information local to its MMU. The LSR can be globally 
written but the GAL, GAT, and LIP bits will not be affected. L4-L7 are cleared if F in the GSR is 
cleared on reset. The organization of the LSR is shown below. The LSR is located at address $2F. 



LSR I L7 I L6 I L5 I L4 |rw|GAT|GAL| LIP | 



Address 



RW RW is a status alterable bit which reflects the state of the R/W pin at the time FAULTin 
is asserted. 

Set: a) MPU writes a "1" 

b) When fault occurs during read of segment 

Cleared: a) Reset 

b) MPU writes a "0" 

c) When fault occurs during write of segment 

GAT GAT (global accumulator for translate) is set by the MMU if ACO, AC1, and AC6 are 
globally consistent. See 4,5.3 Global Operations. 

Set: a) If ACO, AC1, and AC6 are globally consistent (they were last modified 
as a result of a global write) 
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Cleared: a) Reset 

b) If ACO, AC1 , and AC6 are not globally consistent 

GAL GAL {global accumulator for load) Is set if ACO, AC1 , AC2, ACS, AC6, and ACS are 
globally consistent. 

Set: a) If ACO, AC1, AC2, ACS, AC6, and ACS are globally consistent 
Cleared: a) Reset 

b) If ACO, AC1 , AC2, ACS, AC6, and ACS are not globally consistent 

LIP LIP (local interrupt pending) is set if one or more descriptors have IP set in their seg- 
ment status registers. 
Set: a) If IP is set in any descriptor 
Cleared: a) Reset 

b) If all IP bits are clear 

LA-L7 The status information encoded in L4-L7 reflects the status of the MMU after the last 

event (an operation or fault). These bits are encoded and changed as a unit. They are 
cleared whenever the F bit in the GSR is cleared and are alterable by the MPU. 

L7 L6 L5 L4 

0 0 0 0 NO The MMU was not the source of the last event. 



1 0 0 0 DT A direct translation was locally successful. A match was found in 
one of the MMU descriptors. 

1 0 0 1 LD A load descriptor fault occurred. A previously defined descriptor 
conflicts with the descriptor being loaded. 



10 10 USA An undefined segment access was attempted. The logical address 
was not matched in any descriptor in the MMM. 



110 0 WV A write violation occurred. A segment defined in the MMU was 
write protected and a write to that memory segment was 
attempted. The NVR bit in the RDP will show whether the USA or 
WV occurred in the MMU. See 3.2.6 Result Descriptor Pointer 
(RDP). 



Set: a) Various bits set if DT, LD, USA, or WV occur 

b) MPU writes a "1" 

Cleared: a) Reset 

b) MPU writes a "0" 

c) When F bit in GSR is cleared 

d) If MMU was not the source of the last event (NO) 



3.2.5 Descriptor Pointer (DP) 

The DP is an 8-bit read/write pointer register located at address $29. The five low-order bits identify 
the descriptor to be used in the load descriptor, read segment status (transfer descriptor), and write 
segment status operations. Bits 5, 6, and 7 are reserved. 



3-7 



The DP is initialized to $00 on reset. It can be globally written by the MPU. The DP is loaded by the 
MMU with the number of the descriptor matched in a direct translation operation to allow a subse- 
quent transfer descriptor operation to load the match descriptor into the accumulator. See 4.6.3 
Global Operation and 4.6.3.3 Direct Translation. 

7 6 5 4 3 2 1 0 

DP I I I |dp4|dp3|dp2|dpi|d;^ ^"^^^"'^ 



$29 



3.2.6 Result Descriptor Pointer (RDP) 

The RDP is an 8-bit, read-only register that identifies a descriptor involved in the following events: a 
write violation, a load descriptor failure, or a direct translation success. The RDP is loaded from a 
priority encoder which determines the highest priority descriptor involved. For example, in a load 
descriptor operation, more than one descriptor currently in the MMU may collide with the descrip- 
tor being loaded. Only the number of the highest priority descriptor will be loaded into the RDP. 
Descriptor 0 is considered to be the highest priority and 31 is the lowest. 

The RDP bit assignments are shown below. Bits 5 and 6 are reserved. The RDP is initialized to $80 
on reset. The RDP is located at address $3B. 

7 6 5 4 3 2 1 0 
RDP |NVR| I |R4|r3|r2|r1 |ro| 

NVR If no descriptor is selected by the priority encoder when the RDP is loaded, NVR (no 
valid result) is set; otherwise, it is cleared. This bit is status unalterable. 
Set: a) Reset 

b) No result from WV, LD, or DT 
Cleared: a) AWV, LD failure of DT success in MMU 

R0-R4 R0-R4 encode the number of the descriptor selected by the priority encoder. 



3.2.7 Interrupt Descriptor Pointer (IDP) 

The IDP is an 8-bit read-only register that is read to determine which descriptor caused an interrupt. 
Each time it is read, the IDP is loaded from the priority encoder with the highest-priority descriptor 
which has IP set in its SSR. If no descriptor has IP set, the no valid interrupt (NVI) bit is set. See 
4.6.2.1 Interrupt Acknowledge. 

The bit IDP assignments are shown below. Bits 5 and 6 are reserved. The IDP is located at address 
$39. 

7 6 5 4 3 2 1 0 
IDP I NVI I I I 14 I 13 I 12 I II I 10 I $39 

NVI NVI is set if no descriptor has IP set; otherwise, it is cleared. 

10-14 These bits encode the number of the descriptor selected by the priority encoder. 
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3.2.8 Interrupt Vector Register (IVR) 



The IVR is an 8-bit read/ write register containing the interrupt vector. Its contents are placed on the 

data lines, D0-D7, during the interrupt acknowledge operation to provide the processor with a vec- 
tor number. The IVR is initialized to $0F (the MC68000 uninitialized-device vector number) on reset. 
The IVR is located at address $2B. 

7 6 5 4 3 210 
IVR I IV7 I IV6 I IV5 I IV4 | IV3 | IV2 | IV1 | IVo] ^2b'^^^ 
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SECTION 4 
MMU FUNCTIONAL DESCRIPTION 



4.1 SINGLE-MMU SYSTEMS 

The memory management mechanism can be comprised of one or more memory management 
units. Implementing memory management using the MC68000 or MC68010 MRUs and a single 
MC68451 is straightforward. Two SN74LS245 type bidirectional buffers are needed to demultiplex 
the physical address/ data port (PAD0-PAD15). These are directly controlled by the enable data 
(ED) and read/ write (R/W) lines. Two SN74LS373 type transparent latches are used to latch the 
translated address when the PAD p ort is needed to transfer data to or from the MPU. These latches 
are controlled by the hold address (HAD) line. A circuit diagram of a single-MMU system is shown 
in Figure 4-1. 

The MMU may also be used with the MC68008 8-bit data bus version ofthe MC68000. This requires 
only a few gates to synthesize the upper and lower data strobe signals (UDS and LDS) from address 
line AO and data strobe (DS) on the MC68008. Since there is only one data strobe in an MC68008 
system, the physical data strobe generation is somewhat simpler; otherwise, the circuit is identical 
to that of the MC68000 system. A circuit diagram of a single-MMU system using the MC68008 MPU 
is shown in Figure 4-2. 

4.2 MULTIPLE-MMU SYSTEMS 

If more than 32 descriptors are needed for performance enhancement reasons, multiple MMUs may 
be configured in a system. The number of MMUs that can be used is not logically constrained. In 
practice, buffer drive limitations limit the number to six MMUs without using additional external 
buffering. 

A circuit diagram showing two MC68451s in a system with the MC68000 or MC68010 is shown in 
Figure 4-3. Notice that t he dat a buffers and address latches are shared by both MMUs and need not 
be duplicated. The GO, ANY, and ALL lines are bused together to provide the inter-MMU hand- 
shake necessary for the global operations as outlined below. Notice that only one of the MMUs is 
chip-selected on RESET. This selects the master out of reset. For more information refer to 4.5.1 
The Reset State. 

In order to perform its operations, some of the information in MMU registers must be global. 
That is, it must be duplicated in all the MMUs in the system. For example, the address space table 
must be global to insure that the address space numbers are common to all MMUs. To allow this, 
certain operations are defined as global. Any system register that can be written, is written globally. 
This includes the accumulator, the address space table, the descriptor pointer, the interrupt vector 
register, the global status register, and the local status register. The result descriptor pointer and 
the interrupt descriptor pointer are read only and, therefore, are local and not global. 
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Figure 4-1. Single-MMU System with IVIC68000 or IVIC68010 
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Figure 4-2. Using the MC68008 with the MMU 
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Figure 4-3. Sample Circuit Diagram of a Two-MMU System 
with the MC68000 or MC68010 



The ANY, ALL, and GO signal lines are used to connect multiple MMUs to form the MMM. The 
MMM uses these input/output signals to communicate information between MMUs and maintain 
functional unity. The GO (global operation) pin i s used to establish the master-slave relationship 
between MMUs for a given operation. The ANY signal is detected as true if any MMU asserts it, 
allowing MMUs to report conditions that are important in even one device. The ALL signal is 
detected as true only if all MMUs assert it. It is used to verify that all MMUs in the system have per- 
formed some operation or are in the same state. A sample circuit diagram of a two-MMU system us- 
ing the MC68000 or MC68010 is shown in Figure 4-3. 

During each global operation, one MMU is specified as the master; all others are designated as 
slaves. The MMU which has its chip select (CS) asserted becomes the master by asserting the 
GOout signal. This signals the other MMUs that they are slaves for that operation. Note that all 
MMUs may be accessed and, therefore, any one may be the master for a given operation. 

4.3 MMU TIMING 

The MC68451 is a hybrid machine. The normal translation function is implemented in combinational 
logic for maximum speed. The operations (reading and writing registers, etc.) are implemented with 
a synchronous finite state machine. Due to the asynchronous nature of the signals used to com- 
municate between MMUs, the timing of these operations will vary due to a number of factors, in- 
cluding the placement of AS, the speed of translations, the relationship of CS to the internal clocks, 
and the need to internally synchronize the input signals. Because of this, timing diagrams are 
shown with breaks to indicate a variable number of clock periods between events. 

4.4 MMU FLOW DIAGRAM 

In order to give a functional description of the MMU, the flow diagrams of the device are given in 
Figure 4-4. Each box contains certain actions (loading registers, asserting signals, etc.) and the 
paths leading from it are labeled with a signal name or logical expression of signal names. If the 
signal or expression is true, that branch is taken. The only timing information given is the 
chronological order in which events occur. The length of each operation, given in system clock 
cycles, is shown in Table 4-1 . 

NOTE 

In Figure 4-4, all signals are shown as active high regardless of the voltage level of the true 
state. Logical negation is denoted by the prime symbol ('). 

4.5 MMU FUNCTIONAL STATE 

At any time an MMU may be in one of five states: reset, idle, normal translation, local operations, or 
global operations. In a global operation, an MMU may be a master (if the CS signal is asserted) or a 
slave (if GOin is asserted). In addition, two actions can occur regardless of the current state: 

1. If RE SET is asserted, the reset operation begins. The MMM will remain in the reset state 
until RESET is negated. 

2. IRQout is asserted if the local interrupt pending bit in the local status register and interrupt 
enable in the global status register are set; otherwise, it is placed in the high-impedance 
state and should be negated with a pullup resistor. 
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NOTES: 

1 . In this figure, all signals are shown as active high regardless of the voltage level of the true state. Logical negation is denoted by 
the prime symbol ('). 

2. Individual bits in registers are denoted as REG (bit); e.g., LSR (GAL) represents the GAL bit in the LSR. 



LEGEND: 

T = Signal is three-stated. 

RE = Rescind. Signal is driven high, 
then three-stated. 

DRE = Delayed rescind. HAD is rescind- 
ed one-half clock period after 
MAS. 



N = Signal is negated. 

R = Range Match 

S = Space Match 

P = Privilege Match (not a write with 

WP set) 
Dx = Descriptor ifx (0-31) 



PE = Priority Encoder 
PA = Physical Address 
COLL = A collision occurred during 

descriptor operation. 
RL = Low-order byte of register 
RH = High-order byte of register 



Figure 4-4. MMU Flow Diagram (Sheet 1 of 3) 
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NOTES: 

1 . In this figure, all signals are shown as active high regardless of the voltage level of the true stale. Logical negation is denoted by the prime symbol (') 

2. Individual bits in registers are denoted as REG (bit), e.g., LSR (GAL) represents the GAL bit in the LSR. 
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Table 4-1. Length of Operations 



Operation 


Length 
(Clock Periods) 


Single MMU 




Min 


Max 


Read System Register (Except IDP) 


13 


15 


Read Interrupt Descriptor Pointer 


21 


23 


Write System Register (Except Segment Status) 


17 


19 


Write to Segment Status Register 


11 


13 


Load Descriptor (No Error) 


33 


35 


(Collision Error) 


27 


29 


(No GAL) 


21 


23 


Direct Translation (No Error) 


25 


27 


(Undefined Segment) 


27 


29 


(No GAT) 


19 


21 


Read SSR and Transfer Descriptor 


17 


19 


Interrupt Acknowledge 


13 


15 


Null Operation (Read) 


11 


13 


Null Operation (Write) 


9 


11 


Multiple MMU 




Min 


Max 


Read System Register (Except IDP) 


13 


15 


Read Interrupt Descriptor Pointer 


21 


23 


Global Write System Register (Except Segment Status) 


21 


29 


Write Segment Status 


11 


13 


Load Descriptor (No Error) 


35 


43 


(Match- |mj, No Err-(s!) 


27 


29 


(Match-jm!, GAL-{s]) 


35 


43 


(Match- is), No Err- {ml) 


39 


51 


(No GAL-(m!, Match-(sl) 


21 


23 


(No GAL-{m|, No Err-(s!) 


21 


23 


(No GAL-{s), No Err-(mj) 


31 


43 


(No GAL-{s}, No GAL-(m)) 


27 


31 


Direct Translation (Match — {m}. No Err— {s}) 


25 


27 


(Match- {si, No Err-{m)) 


39 


51 


(Match-{m}, No GAT-{s)) 


25 


27 


(Match- |s}. No GAT-{m}) 


39 


51 


(No Match -{m, s}) 


31 


39 


(No Match- [sj. No GAT-fmj) 


31 


39 


(No Match- {mj. No GAT-(s}) 


27 


33 


(No GAT-{mJ, No GAT-{s)) 


23 


31 


Read SSR and Transfer Descriptor 


17 


19 


Interrupt Acknowledge 


13 


15 


Null Operation (Write) 


9 


11 


Null Operation (Read) 


11 


13 



NOTES: 



1 . Length of o peration s are given in system clock periods. The length of the operations is defined from the assertion of CS to the 
assertion of DTACK except in the case of interrupt acknowledge operations. In this case, the timing is given from lACK to DTACK. 

2. These operation le ngths assume that all MMUs have a common system clock. The actual length of a given operation will depend 
upon when CS (or lACK) is asserted at the MMU. In the case of multiple-MMU systems, the length will also depend on the rise and 
fall times of the inter-MMU handshake signals and their relationship to the internal clocks of the MMU. 

3. In multiple MMU operations, the master is denoted by {mJ and the slave is denoted by {sj. The notes 'no GAL' and 'no GAT' in- 
dicate that bit is cleared. 

4. I mmediate ly following an operation to an MMU, the time required for an MMU to re-enter the 'ready for translation' state is: 

DTA CK to ID LE= 10 clock periods maximum 

UDS to LDS negated to IDLE = 8.5 clock periods maximum 
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4.5.1 The Reset State 



Asserting RESET will in i tiate t he re set se quence regardless of the stat e of the MM U. Du ring reset, 
GO, DTACK, ED, MAS, HAD, and WIN are resci nded. T he PAD p ort, FAULT, and ANY are placed 
in the high-impedance state. Pullup resistors on FAULT and ANY keep these signals negated. The 
ALL pin is driven low to negate it. 

The GSR, LSR, DP, and the entire address space table are initialized to $00. The RDP is initialized to 
$80 and the IVR to $0F. All descriptors are disabled by clearing the enable bits in their segment 
status registers. 

In order to allow the address bus to function before the operating system can initialize the MMM, 
one MMU is selected to have descriptor #0 initialized so that it maps any logical address unchanged 
to the physical address bus. The MMU is selected for this by having its chip-select line asserted dur- 
ing reset. This circuit is shown in Figure 4-3. 

Descriptor 0 in the selected MMU will have had its LAM and ASN cleared to $00, its ASM set to 
$FF, and the enable bit set. Because of this, the logical address passes to the physical address bus 
(via descriptor #0) without alteration. The enable bits of descriptors 1-31 are cleared to disable them 
and their contents remain uninitialized. If the chip selected (CS) is not selected during reset, the 
enable bits in all descriptors are cleared and no descriptor is initialized. 

A flow diagram for the reset state is given in Figure 4-5. 

NOTE 

In Figure 4-5, all signals are shown as active high regardless of the voltage level of the true 
state. Logical negation is denoted by the prime symbol ('). 



(From Any State) 
i RESET 



T: PAD0-PAD15 
T: FAULT 
T: ANY 
N: ALL 
RE: GO 



RE: DTACK 
RE: ED 
RE: MAS 
RE: WIN 
RE: HAD 



GSR, LSR, * $00 
ASTO-15, DP * $00 
RDP * $80 
IVR * $QF 
SSRO-31 (E) *- 0 



CS • RESET' 



NOTES: 

1 . In this figure all signals are shown as ac- 
tive high regardless of the voltage level 
of the true state. Logical negation is 
denoted by the prime symbol ('). 

2. Individual bits in the registers are 
denoted as REG (bit); e.g., LSR (GAL) 
represents the GAL bit in the LSR. 



CS • RESET 

T 

SSR0*$01 
LAMO. ASNO*$00 
ASMO*$FF 



RESET' 




LEGEND: 
T = Signal is three-stated. 
RE = Rescind. Signal is driven high, 

then three-stated. 

DRE= Delayed rescind. HAD is r escind ed 

one-half clock period after MAS. 
N = Signal is negated. 



Figure 4-5. Reset Flow Diagram 
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4.5.2 The Idle State 

The idle state is used to terminate bus accesses and prepare for new ones. The MMU is "bacl<ed- 
off" the bus; i.e., the data transceivers are placed in the high-impedance state and the address 
latches are put into the transparent mode. The o utput s are driven to the same levels as in reset ex- 
cept that HAD Is rescinded one-half clock after MAS to provide address hold time. 

While In the Idle state, the MMU uses the function code Inputs to Index Into the AST to provide the 
cycle ad dress s pace number. If AS is asserted, a normal translation is performed. If AS is negated 
and CS, lACK, IRQin, GO, and the data strobes indicate an access from the physical bus, an opera- 
tion is performed. For further information, see 4.6 MMU OPERATIONS. 

4.5.3 Normal Address Translation 

At the start of a bus cycle, the processor presents the logical address, R/W, and the function code 
to the MMM. The function code is used to index into the address space table to select the cycle 
address space number. When AS Is asserted, the normal_translatlon phase begins by sending the 
cycle address space number, the logical address, and R/W to each descriptor for matching. 

NOTE 

The function codes must be valid before AS Is asserted to allow for the table lookup. Cur- 
rent versions of the MC68000 provide this setup time; however, early mask sets (R9M, 
T6E, BF4) do not. With these early mask sets, AS must be delayed to the MMU. 

4.5.3.1 MATCHING. Matches can occur in two areas: range and space. A range match occurs if, in 
each bit position in the LAM which is set, the incoming logical address matches the LBA. A space 
match occurs if, in each bit position In the ASM which is set, the cycle address space number 
matches the ASM. 

4.5.3.2 SUCCESSFUL TRANSLATION. An address match occurs if there is a range match and a 
space match. A write violation occurs if a write is attempted to a write- protected segment. If there 
Is an address match in a descriptor and no write violation, the physical address Is formed from the 
PBA of that descriptor and the logical address. The logical address Is passed through in those bit 
positions in the LAM which are clear (the "don't cares"). In the other bit positions, the PBA Is gated 
out to the physical address bus. 

The U and, if the cycle w as a w rite, the M bits in the segment status register are set. If the I bit is 
set, then the IP bit is set. WIN Is asser ted if the WP bit Is set and the cycle was a read or a read- 
modify-write. If the cycle was a write, MAS is not asserted to prevent the write from modifying 
data. 
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After the physical address is stable, MAS is asserted to indicate a valid address is on the bus. HAD 
is asserted to hold the address stable on the latches and the PAD0-PAD15 lines are then placed in 
the high-impedance state. If AS is then negated, the cycle has terminated and the MMU returns to 
the idle state. A functional timing diagram for a normal translation in a two-MMU system is shown 
in Figure 4-6. If AS is not negated, the cycle can continue in three ways: 

1. If CS or lACK and IRQin are asserted, the MMU will begin an operation as a master. See 
4.6.3 Global Operations. 

2. If GOin is detected by an MMU, it will begin a slave operation. See 4.6.3 Global Operations. 

3. If a high-to-low transition is detected on R/W (indicating a write) AS remains asserted, and 
the matched segment is write protected, a write violation occurs. The WIN signal is asserted 
to protect the memory. This would be the result of a read- modify- write bus cycle on a pro- 
tected segment. 

4.5.3.3 WRITE VIOLATION. If an address match occurs but the bus cycle was a write to write- 
protected segment, a write violation occurs. In this case, the RDP is loaded from the priority en- 
coder, F is set in the GSR, and DF is set if F was previously set. The state of the R/W line is latched 
into the RW bit of the LSR and L4-L7 are encoded to indicate write violation (WV). The FAULTout 
signal is then asserted for five clock cycles or until AS is negated, whichever is longer. 

The logical address is latched into AGO (MSB) and AC1 (LSB) of the accumulator (see Table 3-1). 
The cycle address space number is latched into AC6. These registers are marked as non-global with 
respect to the GAT and GAL bits. If the FAULT pin has been connected to the BERR pin on the 
MC68000, AS will be negated as the MPU begins the bus error exception processing. When AS is 
negated, the MMU will enter the idle state. 

A functional timing diagram for a translation with a write violation is shown in Figure 4-7. The 
breaks in the diagram reflect the uncertainty due to the deskewing of the input signals from other 
MMUs. 

4.5.3.4 NO ADDRESS MATCH. If none of the de scriptors in an MMU has an address match, that 
MMU asserts ALLout, and monitors MASin, FAULTin, and ALLin. There are then three 
possibilities: 

1. The access was successfully translated in another MMU. See 4.5.3.5. EXTERNAL 
TRANSLATION. 

2. The access caused a write violation in another MMU. See 4.5.3.6 EXTERNAL WRITE 
VIOLATION. 

3. The access was to a globally undefined segment. See 4.5.3.7 UNDEFINED SEGMENT 
ACCESS. 



4.5.3.5 EXTERNAL TRANSLATION. If MASin becomes asserted, the access was successfully 
translated by another MMU. The MMU negates ALLout and prepares to end the normal translation 
phase. The cycle can then continue in one of three ways: 

1. If AS becomes negated, the MMU returns to the idle state. 

2. If CS, or lACK and IRQin are asserted, the MMU begins an operation as a master. 

3. If GOin is detected true, the MMU begins an operation as a slave. 
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Figure 4-6. Normal Translation Timing on a Two-MMU System 
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Figure 4-7. Write Violation Timing 



4.5.3.6 EXTERNAL WRITE VIOLATION. If the FAULTin line is detected true (low), a write violation 
occurred in another MMU. The detecting MMU then sets the F bit in the GSR and the DF bit if the F 
bit was already set. R/W is latched into the RW bit of the LSR, and L4-L7 are cleared to show that 
the violation did not take place in the MMU. The cycle can then continue in one of the three ways 
described in 4.5.3.5 EXTERNAL TRANSLATION. 

4.5.3.7 UNDEFINED SEGMENT ACCESS. If ALLin is detected true (high), none of the other MMUs 
in the system obtained a match, indicating the segmentjs globally undefined. The MMU sets the F 
bit in the GSR and the DF bit if F was set previously. R/W is latched into the RW bit of the LSR and 
L4-L7 are encoded to show a USA. 



The logical address (A8-A23) is latched into the accumulator, AGO (MSB) and AC1 (LSB), and the 
cycle address space number is latched into AC6. These registers are marked non-global with 
respect to the GAL and GAT bits. 

All MMUs assert the FAULT line for five clock periods or until AS is negated, whichever is longer. 
To assure the detection of ALLin by all MMUs, ALLout remains asserte d for tw o clock cycles after 
ALLin is detected true. ALLout is negated before the beginning of the FAULT pulse. When AS is 
negated, the MMM returns to the idle state. 

A functional timing diagram for an undefined segment access is given in Figure 4-8. The breaks in 
the diagram reflect the uncertainty due to the deskewing of the input signals from other MMUs. 
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Figure 4-8. Undefined Segment Access Timing 



4.6 MMU OPERATIONS 



Table 4-2 shows the operations which can be performed. Each operation is initiated by the access of 
an address given on the register select lines RS1-RS5 and the upper and lower data strobes. The ac- 
cess can be from either the logical or physical address bus. in a multiprocessor system, an external 
processor could access the MM M from the physical address bus. If the access is from the logical ad- 
dress bus, and address translation is first performed. If the access is from the physical address bus, 
the operation state is entered directly from the idle state. 



Table 4-2. Summary of MMU Functions 



Function 


Summary 


Idle 


The MMU backs off the bus to prepare for a new access. 


Reset 


The MMU is pre-emptively initialized. 


Normal Translation 


The MMU attempts to translate an access from the logical address bus. 


Operations 


The MMU is accessed from the logical or physical bus. 


Write System Registers 


An operation to globally write system registers. 


Read System Registers 


An operation to read the system registers. 


Write Segment Status 


The SSR of a descriptor can be quickly changed using this operation. 
The enable bit cannot be set using it, however. 


Load Descriptor 


With this operation, the contents of the accumulator are loaded into the 
descriptor pointed to by the descriptor pointer. 


Transfer Descriptor 


This operation transfers the contents of the sleeted descriptor into the 
accumulator. 


Direct Translation 


An operation to globally translate a logical address for the operating 

system. 


Interrupt Acknowledge 


An operation that supplies a vector number to the MRU in response to 
lACK. 



The operation phase is always entered with PAD0-PAD15 in the high-impedance state and either (in 
the case of an operation following a normal translation) one MMU asserting HAD to hold the 
physical address, or (jr^the case of an ac ce ss fro m the physical b us) th e ext erna l processor holding 
the address. I^oth CS and either UDS or LDS are asserted or lACK and IRQin are asserted, the 

MMU asserts ED to enable the data transceivers. 

If lACK and IRQin and UDS or LDS are asserted, an interrupt acknowledge operation is performed. 
If CS and UDS or LDS are asserted, the MMU determines which operation to perform by decoding 

RS1-RS5 and R/W. These signals tell which register is associated with the operation, which opera- 
tion to perform, and whether the operation is local or global. 



After each operation, DTACK is as serte d to in dicate t o the_processor that the operation is finished. 
When the processor negates UDS and_LDS, DTACK and ED are rescinded and PAD0-PAD15 are 
placed in the high-impedance state. If AS is negated, or had been negated since the last normal 
translation, the MMU enters the idle state. 



After the DTACK handshake, if AS remains asserted and CS and UDS o r LDS ar e asse rted, another 
master operation is performed. If AS remains asserted and GOin and UDS or LDS are asserted, 
another slave operation is performed. 
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4.6.1 Operations Address Map 

Table 4-3 shows the operations address map. Each system register has an address at which it can be 
read or written. In addition, some addresses do not correspond to a register, but rather designate an 
operation to be performed by reading that location. 

The data strobes are loglcally separate and operations using both are independent. The operation 
ends when both data strobes are negated. 

Some addresses are reserved for future expansion. Any access to an unused location will result in a 
null operation. If the access is a read, the appropriate byte of the data bus is driven high. If the ac- 
cess is a write, no side-effect occurs. 



Table 4-3. Register/ Operations Address Map 



Address 


Operation 


Register or Operation 


Binary 


Hex 


RRRRRR 
SSSSSS 
543210 


R 


w 


000000 


00 


L 


G 


AST 0 (Alternate, FC3=0) 


000010 


02 


L 


G 


AST 1 (User Data) 


000100 


04 


L 


G 


AST 2 (User Program) 


0001 10 


06 


L 


G 


AST 3 (Alternate, FC3=0) 


001 000 


08 


L 


G 


AST 4 (Alternate, FC3=0) 


001010 


OA 


L 


G 


AST 5 (Supervisor Data) 


001100 


OC 


L 


G 


AST 6 (Supervisor Program) 


001 1 1 0 


OE 


L 


G 


AST 7 (Interrupt Acknowledge) 


01 0000 


10 


L 


G 


AST 8 (Alternate, FC3=1) 


01 001 0 


12 


L 


G 


AST 9 (Alternate, FC3=1) 


010100 


14 


L 


G 


AST 10 (Alternate, FC3=1) 


010110 


16 


L 


G 


AST 11 (Alternate, FC3=1) 


01 1 000 


18 


L 


G 


AST 12 (Alternate, FC3=1) 


011010 


1A 


L 


G 


AST 13 (Alternate, FC3=1) 


011100 


IC 


L 


G 


AST 14 (Alternate, FC3 = 1) 


011110 


IE 


L 


G 


AST 15 (Alternate, FC3= 1) 


100000 


20 


L 


G 


AGO (LBA/Translation ADDR 










(IVIBS)) 


1 00001 


21 


L 


G 


AC1 (LAB/Translation ADDR 










(LSB)) 



Address 


Operation 


Register or Operation 


Binary 


Hex 


RRRRRR 
SSSSSS 
543210 


R 


W 


100010 


22 


L 


G 


AC2 


(LAM (MSB)) 


100011 


23 


L 


G 


AC3 


(LAM (LSB)) 


100100 


24 


L 


G 


AC4 


(PBA/Translated ADDR 












(MSB)) 


1 001 01 


25 


L 


G 


AC5 


(PBA/Translated ADDR 












(LSB)) 


100110 
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4.6.2 Local Operations 

Some operations, such as reading the status registers, affect only one MMU. These are called local 
operations. Local operations include: interrupt acknowledge, read system registers, transfer 
descriptor, and write segment status register. 
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4.6.2.1 INTERRUPT ACKNOWLEDGE. The interrupt acknowledge operation is performed if lACK 
and IRQin are asserted at the beginning of the operation phase. During interrupt acknowledge, the 
contents of the interrupt vector register are placed on D0-D7, to provide the MPU with a vector 
nunnber. A timing diagram of the interrupt acknowledge operation is shown in Figure 4-9 

4.6.2.2 READ SYSTEM REGISTER. Each system register has an address at which it can be read. 
Each MMU should be chip selected at a different location to access the registers in each. During a 
processor read of the IDP, the IDF is first loaded from the priority encoder and then gated onto 
D0-D7. An example timing diagram of this operation is shown in Figure 4-10. 

4.6.2.3 TRANSFER DESCRIPTOR. In order to read the contents of a descriptor, they must be 
transferred into the accumulator and read from there. The descriptor pointer is first written by the 
processor with the number of the descriptor desired. The transfer descriptor operation is then per- 
formed by reading from the SSR address ($31). 

The contents of the selected descriptor are then transferred into the accumulator as sown in Table 
4-3 and the contents of the SSR are gated onto D0-D7. The descriptor registers may then be read 
from the accumulator. 

4.6.2.4 WRITE SEGMENT STATUS REGISTER. The SSR of any descriptor can be written using 
descriptor pointer (DP) as a pointer. Any bit may be written except the E bit. Enable may be cleared 
using this operation but it may not be set. 

4.6.2.5 NULL OPERATION. A read or write of any location which is not a reg ister will result in a null 
operation. In the case of a read, the data bus will rea d $FF and the DTACK signal will be asserted 
ending the bus cycle. In the case of a write, DTACK is asserted and no other effect occurs. 

4.6.3 Global Operations 

A global operation is one which is performed in parallel on all MMUs in the system. Global opera- 
tions include all writes to system registers, the load descriptor operation, and direct translation. In 
global o perat ion, one MMU is the master and the rest are slaves. The operation begins with OS and 
UDS or LDS asserted on one MMU. The MMU with CS asserted becomes the master for that 
operation. The master asserts GOout and, upon detecting GOin as true, the other MMUs become 
slaves in the operation. 

The ANY, ALL, and GO pins must have pullups to Vcc. even if there is only one MMU in the 
system. In the case of a single-MMU system, global operations then become local only. 

4.6.3.1 WRITE SYSTEM REGISTER. Each system register that can be written to is written globally. 
This includes: AC0-AC8, AST0-AST15, DP, IVR, GSR, and LSR. The operation is performed by 
writing to the address of the desired register (see Figure 4-11). 
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Figure 4-9. Interrupt Acknowledge Timing 
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Figure 4-10. Read System Register Timing 
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Figure 4-11. Global Write Systems Register Timing 
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The MMU which has CS asserted becomes the master by asserting GOout. The other MM Us detect 
GOin and become slaves. Each MMU transfers the data on the data bus to the selected register. If 
the write is to a byte of the accumulator, that register is marked as global. If F is cleared in the GSR, 
L4-L7 are also cleared. 

When the transfer is completed in each MMU, each will assert ALLout. After all MMUs have 
asserted ALLout, ALLin will be true and, upon detecting ALLin, the master rescinds GO. 

4.6.3.2 LOAD DESCRIPTOR OPERATION. Descriptors are loaded by transferring the contents of 
the accumulator to the descriptor after performing global checks for collisions. A collision exists 
when two or more enabled descriptors are programmed to translate the same logical address. 

To prepare for descriptor loading, the accumulator must be loaded globally with the LB A, LAM, 
ASN, and ASM as described in 3.2.2 Accumulator. To make global collision checks, AGO, AC1, 
AC2, ACS, AC6, and ACS must have been globally loaded. If they are, the global accumulator for 
load (GAL) bit in the LSR of each MMU is set. To initiate the operation, a read from address $3F is 
done. If the load is successful, the data bus will be set to $00. If a collision is found, the load is un- 
successful and the data bus is set to $FF. 

During the load descriptor operation, the MMU with CS asserted becomes the master by asserting 
GOout. The other MMUs detect GOin and b ecome slaves. The slave MMUs decode the operation 
from RS1-RS5, R/W, and the data strobes (UDS, LDS). The descriptor whose number is in the 
descriptor pointer is disabled (its E bit is cleared) so that it cannot cause a collision. 



If the GAL bit in the LSR of a slave is clear, L4-L7 is encoded to indicate LD and ANYout are 
asserted. If GAL is set, the slave checks the enable d descriptors against its accumulator for colli- 
sions. If a conflict is found, the slave asserts ANYout and loads its RDP with the numbei_o_f the 
descriptor which cause d the collision. If no collision is detected, L4-L7 are cleared. When GOin is 
detected, ALLout, and ANYout are negated and the operation ends. 

The master aborts the transfer if there is a local descriptor conflict, if the GAL bit is clear, or if 
AN Yin i s asse rted. If the failure was not local, L4-L7 are cleared. Otherwise, L4-L7 are encoded with 
LD and ANYout is asserted by the m aster. The master then puts $FF on D0 -D7 to indicate failure to 
the MRU, negates ALLout and ANYout, and rescinds GOout. When ANYin is negated, the opera- 
tion is terminated. 

If there were no local collisions, the GAL bit of the slave is set, and ALLin is asserted, the master 
completes the transfer and enables the loaded descriptor. It then puts $00 on D0-D7 to indicate suc- 
cess, clears L4-L7, negates ALLout, and rescinds GOout. The example timing diagram in Figure 
4-12 shows a successful load descriptor operation in a two-MMU system. 

4.6.3.3 DIRECT TRANSLATION. The memory management mechanism can be used to directly 
translate the logical address into a physical address and make it available to the processor in the ac- 
cumulator. The logical address to be translated is globally loaded into AC0-AC1 and the ASN to be 
used is loaded into AC6. Translation is initiated with a read from the address $3D. 
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Figure 4-12. Successful Load Descriptor Operation in a Two— MMU System 
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If the translation is successful, the DP and RDP point to the descriptor which performed the transla- 
tion and the physical address is loaded into AC4-AC5. The processor reads $00 from the data bus. 

If the logical address could not be translated because it was globally undefined, the data bus is set 
to $FF to indicate the failure. 

Using AC6 to supply the cycle address space number, each MMU attempts to match the logical ad- 
dress contained in AC0-AC1 with one of its enabled descriptors. Each MMU must have the same in- 
formation in AGO, AC1 , and AC6. The GAT (global accumulator for translation) bit in the LSR is set 
if these registers have each been globally loaded. 

If a match is found, and GAT is set, the physical address is formed as in normal translation and put 
into AC4-AC5. The RDP and DP are loaded from the priority encoder and L4-L7 are encoded to in- 
dicate direct translation (DT). The master puts $00 on D0-D7 to signal that the translation was suc- 
cessful, and rescinds GO to terminate the operation. 

If no match is found, or GA T is cleared, the MMU asserts ALLout and L4-L7 in the LSR are cleared. 
The master monitors ANYin and ALLin. 



If ANYin becomes asserted, then another MMU performs the translation. The master puts $00 on 
D0-D7 to indicate success, negates ALLout, and rescinds GOout. It waits until ANYin is negated 
before terminating the operation. 

If ALLin becomes asserted, then none of the MMUs performed the translation. The master puts $FF 
on D0-D7 to indicate failur e, negates ALLout, and rescinds GOout to terminate the operation. Each 
slave MMU negates ANYout and ALLout when the master MMU rescinds GO at the end of the 
operation. 

4.7 OPERATION LENGTH TABLE 

The length of each operation, in system clock periods, is given in Table 4-1. The table includes 
operation lengths for both the single MMU case and for the multiple MMU situation. Both minimum 
and maximu m numb ers are given. Each operation is measured from the assertion of CS to the 
assertion of DTACK. The minimum number is derived from "ideal" conditions. Each signal is 
assumed to appear at precisely the right time to be used internally for the optimum speed of the 
operation. Parametric timing diagrams are given in Figures 7-2, 7-3, and 7-4. These should be used 
for system hardware design considerations. The flow diagram (Figure 4-4) should be used for 
debugging multiple-MMU systems. 

The example timing diagram in Figure 4-13 shows a successful direct translation operation in a two- 
MMU system. 
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Figure 4-13. Timing for Successful Direct Translation in a Two-MMU System 
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SECTION 5 
HARDWARE CONSIDERATIONS 



5.1 MAS TIMING MODES AND PHYSICAL ADDRESS 

The mapped address strobe (MAS) signals that a valid translated address is present on the physical 
address bus. It should be included in the generation of the physical address strob e (PAS) which is 
then used to gate the mennory decode circuitry. AS is also included in the PAS to effect a quick 
release of the bus at the end of a cycle. 



MAS can be programmed with the MODE pin in three modes: 



Mode A MAS is asserted asynchronously. MAS is asserted as soon as a match for the 
function code and logical address is found, except in the case of a translation 
following an MMU operation. In this case, MAS will be asserted as described in 
Mode S2 below. Two circuits for generating physical address strobe are shown in 
Figure 5-1 (a) and Figure 5-1 (b). 

The circuit in Figure 5-1 (a) uses a delay element to delay MAS to produce PAS. 
The delay time should be equal to the delay from MAS to PAD0-PAD15 valid plus 
the desired setup time for physical addresses required by the user's bus. This cir- 
cuit should be used when the setup time for physical addresses to PAS must be 
greater than parameter 13. Since the setup time from PAD0-PAD15 to MAS valid 
(parameter 13a) may be negative, the delay element must allow for this setup time 
as well as the setup required by the user's physical address bus. 

The circuit shown in Figure 5-1(b) uses a delay element to delay AS to produce 
PAS. The delay value must be equal to the AS to PAD0-PAD15 translation time 
plus the setup required for the user's bus. This circuit should be used when the 
setup time for physic al addresses can be equal to or less than parameter 13. This 
is because the MAS strobe will be delayed until the next falling edge of the clock 
when the previous cycle was an MMU operation. This ass ures a positive address 
setup time equal to the setup time from PAD0-PAD15 to MAS asserted valid in 
mode S2 (parameter 13). This method is preferred if the setup time given in 
paramet er 13 is sufficient for the user's bus since it does not re quire the additional 
delay of PAS due to the delay time of PAD0-PAD15 to MAS valid. 

In either case, the translation time will be longer for translations following an 
MMU operation. See length of operations in Table 4-1 for more information. 



Mode 81 MAS is asserted on the first rising edge of CLOCK after the p hysical address if 
valid. This m ode was intended to allow the generation of PAS by ORing AS and 
MAS. MAS asserts PAS and AS negates it t o rele ase the bus quickly at the end of 
the cycle. A circuit to generate PAS using MAS in mode SI is shown in Figure 
5-1(c). 
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Mode S2 MAS is asserted on the first falling edge of CLO CK a fter the address is valid. This 
mode was Intended to allow the generation of PAS using AS and MAS only. A 
circuit to do this is shown in Figure 5-1 (c). 
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Figure 5-1 . Physical Address Strol3e Generation 
5.2. PHYSICAL DATA STROBES 

The physical data strobes, physica l upp er data strobe (PU DS), and p hysical lower data strobe 
(PLDS), should be generated using UDS or LDS gated with MAS, WIN, and R/W. WIN and R/W 
will prevent the data strobes from bei ng as serted during the write portion of and read-modify-write 
cycle on a write- protected segment. MAS is included to prevent data strobes from being asserted 
on a write cycle of a write- protected segment. A circuit to generate physical data strobes is shown 
in Figure 5-2. Three-state buffers are used to allow access from the physical bus by an external 
processor. 
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Figure 5-2. Generation of Physical Read/Write and Physical Data Strobes 
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5.3 INTERRUPTS 



When the MC68000 responds to an interrupt, it places the interrupt acknowledge (lACK) function 
code on FC0-FC3 and the level of the interrupt to which it is responding onjthe address lines A1-A3. 

This Is not a true nnemory access, but the MMU must translate it since AS Is asserted. To prevent 
the M MU from attempting to translate an address during an Interrupt acknowledge cycle, the 
MASIn signal is forced low. This informs the MMU that the cycle was translated by another MMU. 
However, the MMU will still assert ALLout to show that it could not translate the address. To pre- 
vent ALLin from being asserted and causing a fault, ALL must also be forced low. A circuit to do 
this Is shown in Figure 5-3; however, it is acceptable to dedicate a descriptor to translate the lACK 
access ($FFFFFX), thus eliminating this external circuitry. 
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Figure 5-3. Circuit to Inhibit Translation During lACK 
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SECTION 6 
SOFTWARE CONSIDERATIONS 



6.1 SEGMENT MAPPING EXAMPLE 

In constructing segments, the size of a given segment is determined by the logical address mask. 
Although there are no constraints on which bits are significant, one approach is to allow only con- 
tiguous, low order zeroes ("don't cares"). With this constraint, if there are N zeroes, the size of the 
segment is 2(8+ N) bytes. Since the seven low-order address lines bypass the MMU, the smallest 
possible segment is 128 words (256 bytes). 

In the logical address space, a segment defined this way extends from the address formed by the 
LBA with zeroes in the "don't care" positions in the LAM to the address formed by the LBA with 
ones in the "don't care" bit positions. In the physical address space, the segment extends from the 
address formed by the PBA with zeroes in the "don't care" bit positions in the LAM to the address 
formed with ones in the "don't care" positions. 

This system is ideal for use with the binary buddy algorithm in which segments are all of 2k multiple 
size. 

Figure 6-1 shows an example memory map. In this example, the map has been divided between two 
users and the operating system. The user tasks each have three segments: A, B, and C. The 
operating system also has three segments: 0, V, and R. 

Segment R maps the logical addresses unchanged to the physical address space, but only for 
address space number $00. This segment is automatically generated in descriptor zero in the master 
MMU on reset. Segments 0 and V also belong to the operating system and are accessed only by 
ASNs with bit seven set. This is an arbitrary assignment and need not be followed. 

Segments 1 A, 1 B, and 1 C belong to user number one, and are accessed by address space numbers 
$01 and $81 . User one would be assigned ANS $01 and the operating system would use $81 to 
access those segments. A parallel situation exists with user two. 

Note that segments 1A and 2A are isolated from each other even though they share the same 
logical addresses. User one is prevented from accessing the same memory as user two because his 
ASN does not match segment 2A. Segments can overlap in physical memory, however, as 1C and 
2C do here. 

Note the manner in which segments IB and 2B are defined. Here the logical and physical base 
addresses are considered to be the top of the segment rather than the bottom. This is useful in 
describing push-down, pop-up stacks which grow towards low memory. The same segment can be 
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described in the other way, also. An alternate descriptor for segment 1 B is given below and a 
translation example Is given in Figure 6-2. 
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Figure 6-1 . Address l\^ap Example 
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Physical Address (PA8-PA23) 

Physical address Is formed by passing the logical address (A8-A23) in those positions which are clear ("don't care" bits) in the LAM. In 
the other LAM bit positions (set positions) the PBA is gated out to the physical address bus. 



Figure 6-2. Translation Example 



6.2 SEGMENTATION 



Since segment sizes must be multiples of two, multiple descriptors can be used to map a segment 
of non-binary size. For example, a segment of 70K bytes could be constructed using two descrip- 
tors: one of 64K bytes and one of 8K bytes, losing 2K bytes to internal fragmentation. A purely 
binary system would allocate 128K bytes, wasting 58K bytes. For this reason, a modified binary 
buddy allocation algorithm should be used. 

6.3 VIRTUAL MEMORY SUPPORT 

The MC68451 MMU supports virtual memory systems as well. In a virtual system, the virtual 
address is larger than the physical RAM available and a combination of memory management hard- 
ware and software maintain a portion of the address space on a fast backing store such as a disk. 

Virtual memory systems are usually implemented with a paging type of memory management 
system. In paging systems, the logical (virtual) address space is divided into equal length pages. A 
task is then allocated a certain number of these pages at initial load time and the memory manage- 
ment hardware is programmed to map these virtual pages to physical pages. This is equivalent to 
setting all descriptors to the same length. Thus, the MMU sen/es as a content-addressable transla- 
tion buffer of 32 pages. In such a system, a page fault is caused when an access is attempted to a 
page that is not currently mapped by the MMU. This is an error in a non-virtual system but signals a 
page fault in a virtual system. 

The other ingredient in a virtual system is a processor that is capable of aborting any instruction and 
finishing it a later time. This is necessary because any memory access could potentially be the cause 
of a page fault. When this occurs, the faulting bus cycle is suspended and the operating sytem 
takes corrective action. The bus cycle is then re-run and the instruction is continued. 

The MC68000 does not save enough information when processing a bus error to return and finish 
the instruction that was being executed. Therefore, a true virtual system is not possible using a 
single MC68000 MPU. The MC68010 virtual microprocessor (VMPU) will allow a faulted bus cycle 
to be re-run and the instruction to be continued. This processor can, in conjunction with the 
MC68451 MMU, be used to implement a virtual memory system. 

The MMU also provides hardware assistance for virtual paging systems. The logical address, the 
cycle address space number, and the R/W line are latched in the accumulator on a fault. This infor- 
mation is used by the page fault handler to fix the page fault. In addition, the used and modified bits 
in the segment status register allow the implementation of a variety of page replacement 
algorithms. 

6.4 INITIALIZATION SOFTWARE 

After a reset (power-on or processor initiated), the master MMU (the MMU for which CS was 
asserted during reset) will map the logical addresses unchanged into the physical address space us- 
ing descriptor zero (see 2.6 RESET). This will allow the processor to fetch its supervisor stack and 
program counter (if it was a power-on reset) and begin executing the operating sytem initialization 
routine. See the MC6&0O0 Data Sheet for more information. 
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The operating system would then set up descnptors for itself and system resources (such as the 
MMU). To load a descriptor, the operating system loads the descriptor number in the DP register, 
and the LBA, LAM, PBA, ASN, and ASM into the accumulator as described in 4.6.3.2 LOAD 
DESCRIPTOR OPERATION. 

The processor then reads from the appropriate physical address to begin the loading operation. The 
MMM globally checks for conflicts and loads and enables the descriptor if none are found. As a 
result of the read, the processor gets a status byte in the low byte of the word. The status will read 
$00 if the load was successful and $FF if there was a conflict. If a conflict occurred, the RDP can be 
used to find the highest priority conflicting descriptor. 

A descriptor can be quickly disabled by writing to its segment status register. The I and WP bits can 
be programmed and the U and M bits can be cleared but the E bit can be set only by a load descrip- 
tor operation. 

Descriptors would then be set up for the user tasks and a task would be selected to execute. 
Address space table entries AST1 and AST2 would then be loaded with the address space number 

of the task to be run. These are the address spaces of user data and user program in the MC68000. 
The program counter and status register to be used by the task are then pushed onto the system 
stack. The processor then executes an PTE instruction which fetches the status register and pro- 
gram counter off of the stack. The status register should have had the supervisor bit cleared so that 
the processor will enter the user state and its acesses are then mapped through AST1 and AST2 to 
start the user task. 

To return to the operating system from a user task, a watchdog timer could be used to interrupt the 
processor. The exception processing caused by this would switch the processor to the supervisor 
state and the supervisor address spaces would be mapped by the operating systems descriptors. 

6.5 CONTEXT SWITCHING 

Switching the MMU from one user task to the other is very efficient. Suppose two user tasks were 
present in memory and the processor had returned to the operating system as described above. To 
switch tasks, the operating system would change AST1 and AST2 to the ASN of the user task 
which it wished to execute. It would then push the new status register and program counter on the 
stack and execute an RTE. 

Switching between two supervisor tasks is more complex. If AST5 and AST6 are changed while the 
processor is in the supervisor state, subsequent accesses are immediately mapped through the new 
address space. A move multiple (MOVEM) using the predecrement mode followed by an illegal in- 
struction can be executed to perform the switch. The processor prefetch pipeline fetches the 
MOVEM and the illegal instruction, alters AST6 and AST5 (data entry last), then traps through the 
illegal instruction routine to the new supervisor task. A flag (possibly the illegal instruction opcode) 
is used to distinguish between normal illegal instructions and attempts to switch tasks in this 
manner. 

Another method is to have a task in the user space perform the switch. The supervisor stack pointer 
is set up, the processor alters the status register to put itself in the user state, AST5 and AST6 are 
changed, and the processor traps to the supervisor task. 
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SECTION 7 
ELECTRICAL SPECIFICATIONS 



7.1 MAXIMUM RATINGS 



Characteristics 


Symbol 


Value 


Unit 


Supply Voltage 


vcc 


-0.3 to +7.0 


V 


Input Voltage 


Vin 


-0.3 to +7.0 


V 


Operating Tennperature Range 


Ta 


0to70 


°c 


Storage Temperature 


Tstg 


-55 to +150 





7.2 THERMAL CHARACTERISTICS 



This device contains circuitry to protect the 
inputs against damage due to high static 
voltages or electric fields; however, it is ad- 
vised that normal precuations be taken to 
avoid application of any voltage higher than 
maximum-rated voltages to this high- 
impedance circuit. Reliability of operation is 
enhanced if unused inputs are tied to an ap- 
propriate logic voltage level (e.g., either Vgs 
or Vcc)- 



Characteristics 


Symbol 


Value 


Rating 


Thermal Resistance 








Ceramic 




30 




Plastic 


»JA 


30 


°C/W 


Type B Chip Carrier 




50 




Type C Chip Carrier 




50 





7.3 POWER CONSIDERATIONS 

The average chip-junction temperature, Tj, in °C can be obtained from: 

Tj = Ta+(Pd»^JA) H) 
Where: 

Ta= Ambient Temperature, °C 

6jA= Package Thermal Resistance, J unction- to-Ambient, °C/W 
PD=P|NT+P|/0 

P|NT= 'CC>< VcC/ Watts — Chip Internal Power 
P|/0= Power Dissipation on Input and Output Pins — User Determined 
For most applications P|/0<P|NT and can be neglected. 

An approximate relationship between Pp and Tj (if P|/o is neglected) is: 

PD=K^(Tj-^273°C) (2) 

Solving equations 1 and 2 for K gives: 

K = TD«(TA-K273°C)-t-ejA»PD2 (3) 

Where K is a constant pertaining to the particular part. K can be determined from equation 3 by 

measuring Pq (at equilibrium) for a known Ta- Using this value of K the values of Pd and Tj can be 

obtained by solving equations (1) and (2) iteratively for any value of Ta. 
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+ 5 V 



+ 5V 



MAS, GO, 
IRQ, FAULT, n_ 
ANY, ALL 



:Rl=7500 



:Cl=130 pF 



Test „ 
Point ^ 

Cl=130pF T 
(Includes all Parasitics) -i- 

Rp = 5.6 kft for 

WIN, PAD 0-PAD1 5, 
HAD, ED, DTACK 



MMD6150 
or Equivalent 



Rl=750Q 



til 



MMD7000 
- - or Equivalent 



Figure 7-1. Test Loads 



7.4 AC ELECTRICAL SPECIFICATIONS (Vcc = 5.0 Vdc+5%, GND = 0 Vdc, Ta = 0°C to 70°C, 
see Figures 7-2, 7-3, and 7-4) 







8 MHz 


10 MHz 




iNJumber 


■ ■ 

Characteristic 


Min 


Max 


Min 


Max 


Unit 


1 


C'\r\rAf Porirtrl 
L'lUL.N rcriuu 


125 


500 


100 


500 




£. 


LflOLK VVfUin LOW 


55 


250 


45 


250 




3 


Clock Width High 


55 


250 


45 


250 




4 


Clock Fall Time 


- 


10 


- 


10 






Clock Rise Time 




10 


— 


10 




g 


MO VVIULII Moocl ICU 


200 


- 


180 


— 




7 


rv^u r^o vctiiu LU mo MbbciLcu \\\^ ociujj iiriic/ 


50 


— 


40 


- 




g 


AP-A9'^ Frd-Fn \/a!iH Aftor AQ MonatoH iAHHrocc FP MnlH Timoi 
MO Mzo, r^u rv-..o vdiiu MiLtJr Mo iNcjyciicu iMuutcoo, nulu i trnc/ 


0 


— 


0 


- 






MO Mzo vaiiu 10 Mo Mbberieu (Muuress ociup; 


25 


— 


15 


~ 




10 


A<;<?prtprl tn PAnfl-PADIR Valiii 


— 


150 


- 


125 




1 1 


Mo IvcyolcO lO IVlMo INcQalcU 


— 


100 


— 


75 




12 


AS Asserted to MAS Asserted (Asynchronous Mode) 


— 


150 


— 


125 




13 


PAD0-PAD15 Valid to MAS Asserted (Mode SI or S2) 


30 


— 


25 


— 




13a 


PAD0-PAD15 Valid to MAS Asserted* (Mode A) 


-20 




-20 






14 


Clock High to MAS Asserted (Mode SI) 




80 




60 


ns 


15 


Clock Low to MAS Asserted (Mode S2) 




80 




60 


ns 


16 


Clock High to HAD Asserted 




100 




80 


ns 


17 


Clock High to HAD Negated 




100 




80 


ns 


18 


PAD0-PAD15 Valid to HAD Asserted 


40 




30 




ns 


19 


PAD0-PAD15 Valid after HAD Asserted 


40 




30 




ns 


20 


AS Negated to HAD Negated 


60 




50 




ns 


21 


T^iiS Asserted to R/W Valid 




20 




20 


ns 


22 


R/W High after AS Negated 


40 




40 




ns 


22a 


R/W Low after AS Negated 


0 




0 




ns 


23 


MAS Asserted to R/W Transition (Read-Modify-Write) 


0 




0 




ns 


24 


MAS Asserted to WIN Asserted 




20 




20 


ns 


25 


iVfAS Negated to WIN Negated 


0 


40 


0 


40 


ns 


26 


MAS Asserted to FRQ Asserted 




120 




120 


ns 


27 


Clock High to IRQ Negated 




200 




180 


ns 


28 


AS" Asserted to ALL Hi-Z (No Match) 




200 




160 


ns 


29 


MAS Asserted to ALL Negated (External Match) 




80 




60 


ns 


30 


FAULT Width Asserted 


5 




5 




Clk. Per. 


31 


AS Asserted to FAULT Asserted (USA)** 


8.5 


12.5 


8.5 


12.5 


Clk. Per. 


32 


AS Asserted to FAULT Asserted (WV)** 


13.5 


18.5 


13.5 


18.5 


Clk. Per. 


33 


AS Negated to FAULT Hi-Z (AS Slower than Minimum Width) 




100 




90 


ns 


34 


CS to UDS, LDS Nonoverlap (to Avoid Operation) 


0 




0 




ns 


35 


RS1-RS5, CS, and lACK Valid to Clock Low 


20 




15 




ns 


36 


RS1-RS5 Valid to CS Low 


0 




0 




ns 



* Except immediately following an operation. See Table 4-1 for more information. * * Assumes AS is not a limiting factor. 
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NOTES FOR FIGURES 7-2, 7-3, AND 7-4: 

1 . These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are 
not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related 
diagrams for device operation. 

2. Waveform measurements for all inputs and outputs are specified at: logic high = 2.0 V, logic low=0.8 V. 




FAULT 



Figure 7-2. Normal Translation Timing 



Foldout 1 



CLK 



RSI- :■ 

RS5 ^ -: 



CS 



U PS, 
LDS 



lACK 



ED 



PADO- 
PADT 5 
(Write) 

PA^ 
PADT5 
(Read) 



ANY 



ALL 



DTACK 



^(35) 



<-(35) 



43 



i 



(37)- 



r 



> 



Figure 7-3. Operations Timing 



CLK 



-J "^—Z — "^—T 

(g) >M§^H^ 



CS 



RESET 



Type K (Outputs) 



Type D (Inputs) 



Asynchronous Inputs )l_ 



57) 




Figure 7-4. IVIiscellaneous Signal Timing 



Foldout 2 



Timing Diagrams 
(Timing tables located 
on pages 7-2 and 7-3.) 



7.4 AC ELECTRICAL SPECIFICATIONS (Continued) 

(Vcc = 5.0 Vdc+5%, GND = 0 Vdc, Ta = 0°C to 70°C; see Figures 7-2, 7-3, and 7-4) 



Numbsr 


ChdrsctGristic 


8 MHz 


10 MHz 


Unit 


Min 


Max 


Min 


Max 


37 


LJdid oiroueb iNegci^cu lo no i-noo, uo, anu imun invaiiu 


0 


- 


0 


- 


ns 


do 


uuo, LUo vviaTn iNegateu 


140 


- 


100 


- 


ns 


QQ 

oy 


PAD0-PAD15 Hi-Z to ED AsssrtGd 


60 


- 


40 


- 


ns 


40 


Lu Msseneu lo rAuu-rMuio vaiia ivvnie/ 


- 


40 


- 


40 


ns 


4 1 


uuo, LUo iNegaiea to tu iNegaieu 


- 


100 


- 


50 


ns 


42 


bu Negatea to rAUU-rAUio Hi-z iwnte) 


- 


60 


- 


60 


ns 


yiQ 
4o 


uiocK LOW 10 rAuu-rALJio vaiiu ineao/ 


— 


100 


— 


100 


ns 


44 


PAnri-PAniR VflHH tn nTAPk" AcicsortpH fRpArIi 

PML-'U r/^L/ 1 «J VdllU LU U> 1 M*^r\ /Aooci IcU I ncau/ 


187 


— 


150 


— 




45 




~ 


120 




100 




46 


Plrtf^lc 1 nui/ tn AMY AQQPrtprl (Oiitniit^ 

ImiIUON l_UW LU MINI Mooci LCU IwULpLiL/ 




125 




100 




47 


Clock Low to ANY Hi-Z (Output) 




125 




100 


ns 


48 


Clock Low to ALL Hi-Z (Output) 




125 




100 


ns 


49 


Clock Low to ALL Negated (Output) 




125 




100 


ns 


50 


Clock High to DTACK Asserted 




75 




55 


ns 


51 


UDS, LDS Negated to DTACK Negated 




100 




80 


ns 


52 


CS Valid to RESET Negated (CS Setup before RESET) 


5 








Clk. Per. 


53 


CS Valid after RESET Negated (CS Hold Time after RESET) 


-10 


60 


-10 


60 


ns 


54 


RESET Widtfi Asserted (See Note 1) 


10 




10 




Clk. Per. 


55 


Type K Pins Logic High to Hi-Z (See Note 2) 




100 




100 


ns 


56 


Type D Inputs Fall Time (See Note 3) 




200 




200 


ns 


57 


Type D Inputs Rise Time 




200 




200 


ns 


58 


Asynchronous Input Setup Time 


30 




20 




ns 



NOTES: 



1. Initial power-on-reset pulse sh all be >100 ms to allow for system clock stabilization. 

2. Type K outputs are : DTACK, M AS, WIN. H AD, E D, and GO. 

3. Type D inputs are: FAULT, IRQ, MAS, GO, ANY, and ALL. 



MC68451F — The following parameters, for the MC68451F, differ from those given for the 
MC68451 while all others remain unchanged. 



Number 


Characteristic 


8 MHz 


10 MHz 


Unit 


Min 


Max 


Min 


Max 


10 


AS Asserted to PAD0-PAD15 Valid 




125 




100 


ns 


12 


AS Asserted to MAS Asserted (Asynchronous Mode) 




125 




100 


ns 


13 


PAD0-PAD15 Valid to MA§ Asserted (Mode SI or S2) 


40 




40 




ns 


13a 


PAD0-PAD15 Valid to MAS Asserted* (Mode A) 


-10 




-10 




ns 



•Except immediately following an operation. See Table 4-1 for more information. 



Timing diagrams (Figures 7-2, 7-3, and 7-4) are located on a 
foldout page at the end of this document. 
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7.5 ELECTRICAL CHARACTERISTICS (Vcc = 5.0 Vdc ±5%, GND = 0 Vdc, Ta = 0°C to 70°C) 



Characteristics 


Symbol 


Min 


Max 


Unit 


Input High Voltage All Inputs Except MODE 

MODE 


V|H 


Vss + 2.0 

vcc 


Vcc 


V 


Input Low Voltage All Inputs Except MODE 

MODE 


V|L 


Vss-0.3 


Vss + 0.8 

vss 


V 


Input Leakage Current @ 5.25 V 


l|n 




20 


/.A 


Hi-Z (Off-State) Input Current (Vcc= Max) 
PAD0-PAD15, DTACK, MAS, WIN, ED, GO 


•tS! 




20 


mA 


Output High Voltage (loH= -400 /»A, VoH = 2.4 V) 
All Outputs Except FAULT, IRQ, ANY, ALL 


VOH 


VsS + 2.4 




V 


Output Low Voltage (Vcc= Max) 
(l0L = 5,3 mA) PAD0-PAD15, DTACK, MAS, WIN, HAD, ED, GO 
(Iql= 10.7 mA) FAULT, IRQ, ANY, ALL 


Vol 




0.5 
0.5 


V 


Power Dissipation 


Pd 




1.5 


w 


Capacitance (Package Type Dependent) 
(Vin = OV, Ta = 25''C, Frequencv=1 MHz) 






20 


pF 
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SECTION 8 



8.1 ORDERING INFORMATION (Ta = 0°C to70°C) 

Package Type Frequency 



Ceramic 
L Suffix 



8 MHz 
10 MHz 



Order Number 

MC68451L8 
MC68451L8F 
MC68451L10 
MC68451L10F 



Plastic 
G Suffix 



8 MHz 
10 MHz 



MC68451G8 
MC68451G8F 
MC68451G10 
MC68451G10F 



Type B Leadless 
Chip Carrier 
ZB Suffix 



8 MHz 
10 MHz 



MC68451ZB8 
MC68451ZB8F 
MC68451ZB10 
MC68451ZB10F 



Type C Leadless 
Chip Carrier 
ZC Suffix 



8 MHz 
10 MHz 



MC68451ZC8 
MC68451ZC8F 
MC68451ZC10 
MC68451ZC10F 



Pin Grid Array 
R Suffix 



8 MHz 
10 MHz 



MC68451 R8 
MC68451 R8F 
MC68451R10 
MC68451R10F 
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8.2 PIN ASSIGNMENTS 



64-Pin Dual-in-line Package 



68-Terminal Chip Carrier 



PADO 
MAS 
HAD 
MODE 
WIN 
FAULT 
IRQ 
GND 
FC3 
FC2 
FC1 
FCO 

AS 

RESET 
DTACK 
ED 
UDS 
LDS 
GO 
ANY 
ALL 
TKCK 
CS 
CLOCK 

vc_c 

R/W 
RSI 
RS2 
RS3 
RS4 
RS5 
A8 



C2 
C 

c 



1 • 



64D 
631] 



C6 
C7 
PS 

9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
023 
24 
25 
26 
27 



C 
C 
C 

c 

P28 
29 
IZ|30 
C31 
CI32 



62 
61 
60 

59p 
58P 

57 
56 
55 
54 
53 
52 
51 
50 
49 



47 
46 
45 
44 
43 
42 
41 

40p 
39 
38 
37 
36 
35 
34 
33 



PAD1 
PAD2 
PAD3 
PAD4 
ZIPAD5 
PAD6 
PAD7 
PADS 

vcc 

PAD9 
PAD10 
t2 PADII 

□ PAD12 

□ PAD13 

□ PAD14 
ZI PAD15 
Z] A23 

□ A22 

□ A21 
ZI A20 

□ A19 

□ A18 

□ A17 

□ GND 
A16 

□ A15 

□ A14 

□ A13 

□ A12 

□ All 

□ A10 

□ A9 



'cc- iio.\ 
/w-> V: 



ololS <|<|c3lrj|3|ttl Q 

I I I I I I I I I I 

1 68 



OC«u. U. LL U. C3 

I I I I I I I 









J 



b2' 



i26 



27 



35 



-FAULT 
,-WIN 
- MOD E 

■ HAD 
;-MAS 
■PADO 
-PAD1 
;-PAD2 
,-PAD3 
■PAD4 
|-PAD5 
-PAD6 
;-PAD7 
-PADS 

-Vcc 



I I I I I 



I I I I I I I I 



QDr--coa)or::rMmiD\i-cr)oj^oo5 
'=^,<<<<<<<QQQQQCl"'-' 

< <<<<<! 
a. Q. Q. □. 0. CL 



C3 O 
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68-Terminal Pin Grid Array 



K 


(V) (o; (o) 


^ 

(o) (o^ (o) (o) 


/O (C^ 

(V) (o^ 


J 


000 


0000 


000 


H 


000 




000 


G 


0© 




©© 


F 


©0 


BOTTOM 


©© 


E 


© © 


VIEW 


©© 


D 


0© 




©© 


C 


000 




000 


B 


000 


0000 


000 


A 


000 


0000 


00© 



8 9 10 



Pin Number 


Function 


A1 


CLOCK 


A2 


ALL 


A3 


GO 


A4 


LDS 


A5 


ED 


A6 


DTACK 


A7 


AS 


A8 


FCO 


A9 


FC2 


A10 


GND 


B1 


R/W 


82 


cs 


B3 


lACK 


B4 


ANY 


B5 


UDS 


B6 


RESET 


B7 


FC1 


B8 


FC3 


B9 


IRQ 


BIO 


FAULT 


CI 


RS2 


C2 


RSI 


C3 


vcc 


C8 


GND 


C9 


MODE 


CIO 


HAD 


Dl 


RS3 


D2 


RS4 


D9 


WIN 


D10 


MAS 


El 


RS5 


E2 


AS 


E9 


PADO 


E10 


PAD1 



Pin Number 


Function 


F1 


A9 


F2 


A10 


F9 


PADS 


F10 


PAD2 


Gl 


All 


G2 


A13 


G9 


PAD6 


G10 


PAD4 


HI 


A12 


H2 


A15 


H3 


GND 


H8 


vcc 


H9 


Vcc 


H10 


PAD5 


J1 


A14 


J2 


GND 


J3 


A17 


J4 


A19 


J5 


A21 


J6 


PAD15 


J7 


PAD12 


J8 


RADIO 


J9 


PAD9 


J10 


PAD7 


K1 


A16 


K2 


Do Not Connect 


K3 


A18 


K4 


A20 


K5 


A22 


K6 


A23 


K7 


PAD14 


KB 


PAD13 


K9 


PAD11 


K10 


PADS 
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8.3 PACKAGE DIMENSIONS 



L SUFFIX 

CERAMIC PACKAGE 

CASE 746-01 



64 




33 


I 
















B 






32 


1 


m . 





il— D 



-J G U- ^11— J 



NOTES: 

1. dimensionGSis datum. 

2. positional tolerance fo r leads: 

0.25 (0.010)®|T I A® I 

3. EH IS SEATING PLANE, 

4. DIMENSION "L"TO CENTER OF LEADS 
WHEN FORMED PARALLEL. 

5. DIMENSIONING AND TOLERANCING PER 
ANSI Y14.5, 1973. 



DIM 


MILLIMETERS 


INCHES 


MIN 


MAX 


MIN 


MAX 


A 


80.52 


82.04 


3.170 


3.230 


B 


22.25 


22.96 


0.876 


0.904 


C 


3.05 


4,32 


0.120 


0.170 


D 


0.38 


0.53 


0.015 


0.021 


F 


0.76 


1.40 


0.030 


0.055 


G 


2.54 BSC 


0.100 BSC 


J 


0.20 


0.33 


0.008 


0.013 


K 


2.54 


4.19 


0.100 


0.165 


L 


22.61 


23.11 


0,890 


0.910 


M 




IQO 




10O 


N 


1.02 


1.52 


0.040 


0.060 



G SUFFIX 

PLASTIC PACKAGE 
CASE 754-01 



NOTES: 

1. DIMENSIONS A AND B ARE DATUMS. 

2. m IS SEATING PLANE. 

3. POSITIONAL TOLERANCE FOR LEADS 
(DIMENSION D): 

1-0-100.25(0.010) ®iT|A @|B ®\ 

4. DIMENSION LTO CENTER OF LEADS 
WHEN FORMED PARALLEL. 

5. DIMENSION B DOES NOT INCLUDE 
MOLD FLASH. 

6. DIMENSIONING AND TOLERANCING 
PER ANSI Y14.5, 1973, 



DIM 


MILLIMETERS 


INCHES 


MIN 


MAX 


MIN 


MAX 


A 


81.16 


81.91 


3.195 


3.225 


B 


20.17 


20.57 


0.790 


0.810 


C 


4.83 


5.84 


0.190 


0.230 


D 


0.33 


0.53 


0.013 


0.021 


F 


1.27 


1.77 


0.050 


0.070 


G 


2.54 BSC 


0.100 BSC 


J 


0.20 


0.38 


0.008 


0.015 


K 


3.05 


3.55 


0.120 


0.140 


L 


22.86 BSC 


0.900 BSC 


M 


0" 


150 


QO 


15° 


N 


Q.51 


1.G1 


0.020 


0.040 
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ZB SUFFIX 

TYPE B LEADLESS 
CHIP CARRIER 
CASE 760A-01 




NOTES: 

1. DIMENSION A IS DATUM (2 PLACES). 

2. nniS GAUGE PLANE. 

3. POSITIONAL TOLERANCE FOR 
TERMINALS(D): 68 PLACES 
li|0.25 (0.010) © |T|A©|rCs)| 

4. DIMENSIONING AND TOLERANCING 
PER ANSI Y14.5, 1973. 

5. DIMENSION H PROVIDES THE SIZE FOR 
BOTH THE PAD LENGTH AND THE 
THREE CORNER NOTCHES. 



DIM 


MILLIMETERS 


INCHES 


MIN 


MAX 


MIN 


MAX 


A 


23.83 


24.43 


0.938 


0.962 


B 


15.24 


15.49 


0.600 


0.610 


C 


1.73 


3.05 


0.068 


0.120 


D 


0.84 


0.39 


0.033 


0.039 


F 


1.90 


2.41 


0.075 


0.095 


G 


1.27 BSC 


0.050 BSC 


H 


1.02 


1.52 


0.040 


0.060 


N 


1.14 


2.24 


0.045 


0.088 


R 


23.83 


24.43 


0.938 


0.962 



ZC SUFFIX 

TYPE C LEADLESS 
CHIP CARRIER 
CASE 76001 




NOTES: 

1. DIMENSION A IS DATUM (2 PLACES). 

2. IS GAUGE PLANE. 

3. POSITIONAL TOLERANCE FOR 
TERMINALS(D): 68 PLACES 

It 10-25 (0.010)®|T|A©|R©| 

4. DIMENSIONING AND TOLERANCING 
PER ANSI Y14.5, 1973. 



DIM 


MILLIMETERS 


INCHES 


MIN 


MAX 


MIN 


MAX 


A 


23.83 


24.43 


0.938 


0.962 


B 


15.24 


15.49 


0.600 


0.610 


C 


2.03 


3.05 


0.080 


0.120 


0 


0.56 


0.71 


0.022 


0.028 


F 


1.90 


, 2.41 


0.075 


0.095 


G 


1.27 BSC 


0.050 BSC 


H 


1.02 


1.52 


0.040 


0.060 


N 


1.78 


2.29 


0.070 


0.090 


R 


23.83 


24.43 


0.938 


0.962 
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R SUFFIX 

PIN GRID ARRAY 
CASE 765A-01 





©©00©©©© 
©©©000®© 
©00 ©0 
©0 ©0 
0© ©0 
0© ©0 
0® ©© 
©0® ©©© 
©©©©©00000 
®0©0©©©©©® 



NOTES: 

1. POSITIONAL TOLERANCE FO 
LEADS (68 PLACES): 



•$•1$ 0.13 (0.005) ® 



2. DIMENSIONING AND 
TOLERANCING PER ANSI 
Y14.5, 1973. 



DIM 


MILLIMETERS 


INCHES 


MIN 


MAX 


MIN 


MAX 


A 


26.41 


27.43 


1.040 


1.080 


B 


26.41 


27.43 


1.040 


1.080 


C 


2.10 


2.59 


0.083 


0.102 


D 


0.51 


0.60 


0.020 


0.024 


G 


2.54 BSC 


0.100 BSC 


K 


3.56 


4.14 


0.140 


0.163 


N 


1.83 


2.23 


0.072 


0.088 


R 


15.54 


15.95 


0.612 


0.628 


U 


15.54 


15.95 


0.612 


0.628 


V 


1.79 


2.28 


0.070 


0.090 
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